/** v2.8.0-beta.2 | MIT Licensed */
;
!
function(d) {
    "use strict";
    var t, h = d.document,
        m = {
            modules: {},
            status: {},
            timeout: 10,
            event: {}
        },
        r = function() {
            this.v = "2.8.0-beta.2"
        },
        e = d.LAYUI_GLOBAL || {},
        v = (t = h.currentScript ? h.currentScript.src : function() {
            for (var t, e = h.scripts, o = e.length - 1, r = o; 0 < r; r--) if ("interactive" === e[r].readyState) {
                t = e[r].src;
                break
            }
            return t || e[o].src
        }(), m.dir = e.dir || t.substring(0, t.lastIndexOf("/") + 1)),
        g = function(t, e) {
            e = e || "log", d.console && console[e] && console[e]("layui error hint: " + t)
        },
        b = "undefined" != typeof opera && "[object Opera]" === opera.toString(),
        N = m.builtin = {
            lay: "lay",
            layer: "layer",
            laydate: "laydate",
            laypage: "laypage",
            laytpl: "laytpl",
            form: "form",
            upload: "upload",
            dropdown: "dropdown",
            transfer: "transfer",
            tree: "tree",
            table: "table",
            element: "element",
            rate: "rate",
            colorpicker: "colorpicker",
            slider: "slider",
            carousel: "carousel",
            flow: "flow",
            util: "util",
            code: "code",
            jquery: "jquery",
            all: "all",
            "layui.all": "layui.all"
        },
        s = (r.prototype.cache = m, r.prototype.define = function(t, r) {
            return "function" == typeof t && (r = t, t = []), this.use(t, function() {
                var o = function(t, e) {
                        layui[t] = e, m.status[t] = !0
                    };
                return "function" == typeof r && r(function(t, e) {
                    o(t, e), m.callback[t] = function() {
                        r(o)
                    }
                }), this
            }, null, "define"), this
        }, r.prototype.use = function(o, t, e, r) {
            var n = this,
                i = m.dir = m.dir || v,
                a = h.getElementsByTagName("head")[0],
                u = (o = "string" == typeof o ? [o] : "function" == typeof o ? (t = o, ["all"]) : o, d.jQuery && jQuery.fn.on && (n.each(o, function(t, e) {
                    "jquery" === e && o.splice(t, 1)
                }), layui.jquery = layui.$ = jQuery), o[0]),
                l = 0;

            function s(t, e) {
                var o = "PLaySTATION 3" === navigator.platform ? /^complete$/ : /^(complete|loaded)$/;
                "load" !== t.type && !o.test((t.currentTarget || t.srcElement).readyState) || (m.modules[u] = e, a.removeChild(p), function r() {
                    return ++l > 1e3 * m.timeout / 4 ? g(u + " is not a valid module", "error") : void(m.status[u] ? c() : setTimeout(r, 4))
                }())
            }
            function c() {
                e.push(layui[u]), 1 < o.length ? n.use(o.slice(1), t, e, r) : "function" == typeof t && (layui.jquery && "function" == typeof layui.jquery && "define" !== r ? layui.jquery(function() {
                    t.apply(layui, e)
                }) : t.apply(layui, e))
            }
            if (e = e || [], m.host = m.host || (i.match(/\/\/([\s\S]+?)\//) || ["//" + location.host + "/"])[0], 0 === o.length || layui["layui.all"] && N[u]) return c(), n;
            var p, y = (y = (N[u] ? i + "modules/" : !/^\{\/\}/.test(n.modules[u]) && m.base || "") + (n.modules[u] || u) + ".js").replace(/^\{\/\}/, "");
            return !m.modules[u] && layui[u] && (m.modules[u] = y), m.modules[u] ?
            function f() {
                return ++l > 1e3 * m.timeout / 4 ? g(u + " is not a valid module", "error") : void("string" == typeof m.modules[u] && m.status[u] ? c() : setTimeout(f, 4))
            }() : ((p = h.createElement("script"))["async"] = !0, p.charset = "utf-8", p.src = y + ((i = !0 === m.version ? m.v || (new Date).getTime() : m.version || "") ? "?v=" + i : ""), a.appendChild(p), !p.attachEvent || p.attachEvent.toString && p.attachEvent.toString().indexOf("[native code") < 0 || b ? p.addEventListener("load", function(t) {
                s(t, y)
            }, !1) : p.attachEvent("onreadystatechange", function(t) {
                s(t, y)
            }), m.modules[u] = y), n
        }, r.prototype.disuse = function(t) {
            var o = this;
            return t = o.isArray(t) ? t : [t], o.each(t, function(t, e) {
                m.status[e], delete o[e], delete N[e], delete o.modules[e], delete m.status[e], delete m.modules[e]
            }), o
        }, r.prototype.getStyle = function(t, e) {
            t = t.currentStyle || d.getComputedStyle(t, null);
            return t[t.getPropertyValue ? "getPropertyValue" : "getAttribute"](e)
        }, r.prototype.link = function(o, r, t) {
            var n = this,
                e = h.getElementsByTagName("head")[0],
                i = h.createElement("link"),
                t = ((t = "string" == typeof r ? r : t) || o).replace(/\.|\//g, ""),
                a = i.id = "layuicss-" + t,
                u = "creating",
                l = 0;
            return i.rel = "stylesheet", i.href = o + (m.debug ? "?v=" + (new Date).getTime() : ""), i.media = "all", h.getElementById(a) || e.appendChild(i), "function" != typeof r ||
            function s(t) {
                var e = h.getElementById(a);
                return ++l > 1e3 * m.timeout / 100 ? g(o + " timeout") : void(1989 === parseInt(n.getStyle(e, "width")) ? (t === u && e.removeAttribute("lay-status"), e.getAttribute("lay-status") === u ? setTimeout(s, 100) : r()) : (e.setAttribute("lay-status", u), setTimeout(function() {
                    s(u)
                }, 100)))
            }(), n
        }, r.prototype.addcss = function(t, e, o) {
            return layui.link(m.dir + "css/" + t, e, o)
        }, m.callback = {}, r.prototype.factory = function(t) {
            if (layui[t]) return "function" == typeof m.callback[t] ? m.callback[t] : null
        }, r.prototype.img = function(t, e, o) {
            var r = new Image;
            if (r.src = t, r.complete) return e(r);
            r.onload = function() {
                r.onload = null, "function" == typeof e && e(r)
            }, r.onerror = function(t) {
                r.onerror = null, "function" == typeof o && o(t)
            }
        }, r.prototype.config = function(t) {
            for (var e in t = t || {}) m[e] = t[e];
            return this
        }, r.prototype.modules = function() {
            var t, e = {};
            for (t in N) e[t] = N[t];
            return e
        }(), r.prototype.extend = function(t) {
            for (var e in t = t || {}) this[e] || this.modules[e] ? g(e + " Module already exists", "error") : this.modules[e] = t[e];
            return this
        }, r.prototype.router = r.prototype.hash = function(t) {
            var o = {
                path: [],
                search: {},
                hash: ((t = t || location.hash).match(/[^#](#.*$)/) || [])[1] || ""
            };
            return /^#\//.test(t) && (t = t.replace(/^#\//, ""), o.href = "/" + t, t = t.replace(/([^#])(#.*$)/, "$1").split("/") || [], this.each(t, function(t, e) {
                /^\w+=/.test(e) ? (e = e.split("="), o.search[e[0]] = e[1]) : o.path.push(e)
            })), o
        }, r.prototype.url = function(t) {
            var n, e, o = this;
            return {
                pathname: (t ? ((t.match(/\.[^.]+?\/.+/) || [])[0] || "").replace(/^[^\/]+/, "").replace(/\?.+/, "") : location.pathname).replace(/^\//, "").split("/"),
                search: (n = {}, e = (t ? ((t.match(/\?.+/) || [])[0] || "").replace(/\#.+/, "") : location.search).replace(/^\?+/, "").split("&"), o.each(e, function(t, e) {
                    var o = e.indexOf("="),
                        r = o < 0 ? e.substr(0, e.length) : 0 !== o && e.substr(0, o);
                    r && (n[r] = 0 < o ? e.substr(o + 1) : null)
                }), n),
                hash: o.router(t ? (t.match(/#.+/) || [])[0] || "/" : location.hash)
            }
        }, r.prototype.data = function(t, e, o) {
            if (t = t || "layui", o = o || localStorage, d.JSON && d.JSON.parse) {
                if (null === e) return delete o[t];
                e = "object" == typeof e ? e : {
                    key: e
                };
                try {
                    var r = JSON.parse(o[t])
                } catch (n) {
                    r = {}
                }
                return "value" in e && (r[e.key] = e.value), e.remove && delete r[e.key], o[t] = JSON.stringify(r), e.key ? r[e.key] : r
            }
        }, r.prototype.sessionData = function(t, e) {
            return this.data(t, e, sessionStorage)
        }, r.prototype.device = function(t) {
            var o = navigator.userAgent.toLowerCase(),
                e = function(t) {
                    var e = new RegExp(t + "/([^\\s\\_\\-]+)");
                    return (t = (o.match(e) || [])[1]) || !1
                },
                r = {
                    os: /windows/.test(o) ? "windows" : /linux/.test(o) ? "linux" : /iphone|ipod|ipad|ios/.test(o) ? "ios" : /mac/.test(o) ? "mac" : void 0,
                    ie: !! (d.ActiveXObject || "ActiveXObject" in d) && ((o.match(/msie\s(\d+)/) || [])[1] || "11"),
                    weixin: e("micromessenger")
                };
            return t && !r[t] && (r[t] = e(t)), r.android = /android/.test(o), r.ios = "ios" === r.os, r.mobile = !(!r.android && !r.ios), r
        }, r.prototype.hint = function() {
            return {
                error: g
            }
        }, r.prototype._typeof = r.prototype.type = function(t) {
            return null === t ? String(t) : "object" == typeof t || "function" == typeof t ? (e = (e = Object.prototype.toString.call(t).match(/\s(.+)\]$/) || [])[1] || "Object", new RegExp("\\b(Function|Array|Date|RegExp|Object|Error|Symbol)\\b").test(e) ? e.toLowerCase() : "object") : typeof t;
            var e
        }, r.prototype._isArray = r.prototype.isArray = function(t) {
            var e, o = this.type(t);
            return !(!t || "object" != typeof t || t === d) && (e = "length" in t && t.length, "array" === o || 0 === e || "number" == typeof e && 0 < e && e - 1 in t)
        }, r.prototype.each = function(t, o) {
            var e, r = function(t, e) {
                    return o.call(e[t], t, e[t])
                };
            if ("function" != typeof o) return this;
            if (this.isArray(t = t || [])) for (e = 0; e < t.length && !r(e, t); e++);
            else for (e in t) if (r(e, t)) break;
            return this
        }, r.prototype.sort = function(t, n, e) {
            var o = JSON.parse(JSON.stringify(t || []));
            return "object" !== this.type(t) || n ? "object" != typeof t ? [o] : (o.sort(function(t, e) {
                var o = t[n],
                    r = e[n];
                if (!isNaN(t) && !isNaN(e)) return t - e;
                if (!isNaN(t) && isNaN(e)) {
                    if (!n || "object" != typeof e) return -1;
                    o = t
                } else if (isNaN(t) && !isNaN(e)) {
                    if (!n || "object" != typeof t) return 1;
                    r = e
                }
                t = [!isNaN(o), !isNaN(r)];
                return t[0] && t[1] ? o && !r && 0 !== r ? 1 : !o && 0 !== o && r ? -1 : o - r : t[0] || t[1] ? t[0] || !t[1] ? -1 : !t[0] || t[1] ? 1 : void 0 : r < o ? 1 : o < r ? -1 : 0
            }), e && o.reverse(), o) : o
        }, r.prototype.stope = function(t) {
            t = t || d.event;
            try {
                t.stopPropagation()
            } catch (e) {
                t.cancelBubble = !0
            }
        }, "LAYUI-EVENT-REMOVE");
    r.prototype.onevent = function(t, e, o) {
        return "string" != typeof t || "function" != typeof o ? this : r.event(t, e, null, o)
    }, r.prototype.event = r.event = function(t, e, o, r) {
        var n = this,
            i = null,
            a = (e || "").match(/\((.*)\)$/) || [],
            t = (t + "." + e).replace(a[0], ""),
            u = a[1] || "",
            l = function(t, e) {
                !1 === (e && e.call(n, o)) && null === i && (i = !1)
            };
        return o === s ? (delete(n.cache.event[t] || {})[u], n) : r ? (m.event[t] = m.event[t] || {}, m.event[t][u] = [r], this) : (layui.each(m.event[t], function(t, e) {
            "{*}" === u ? layui.each(e, l) : ("" === t && layui.each(e, l), u && t === u && layui.each(e, l))
        }), i)
    }, r.prototype.on = function(t, e, o) {
        return this.onevent.call(this, e, t, o)
    }, r.prototype.off = function(t, e) {
        return this.event.call(this, e, t, s)
    }, d.layui = new r
}(window);
layui.define(function(a) {
    var i = layui.cache;
    layui.config({
        dir: i.dir.replace(/lay\/dest\/$/, "")
    }), a("layui.all", layui.v)
});
!
function(l) {
    "use strict";
    var t, f = l.document,
        h = function(t) {
            return new r(t)
        },
        r = function(t) {
            for (var e = 0, n = "object" == typeof t ? [t] : (this.selector = t, f.querySelectorAll(t || null)); e < n.length; e++) this.push(n[e])
        };
    (r.prototype = []).constructor = r, h.extend = function() {
        var t, e = 1,
            n = arguments,
            o = function(t, e) {
                for (var n in t = t || ("array" === layui.type(e) ? [] : {}), e) t[n] = e[n] && e[n].constructor === Object ? o(t[n], e[n]) : e[n];
                return t
            };
        for (n[0] = "object" == typeof n[0] ? n[0] : {}, t = n.length; e < t; e++)"object" == typeof n[e] && o(n[0], n[e]);
        return n[0]
    }, h.v = "1.0.8", h.ie = (t = navigator.userAgent.toLowerCase(), !! (l.ActiveXObject || "ActiveXObject" in l) && ((t.match(/msie\s(\d+)/) || [])[1] || "11")), h.layui = layui || {}, h.getPath = layui.cache.dir, h.stope = layui.stope, h.each = function() {
        return layui.each.apply(layui, arguments), this
    }, h.digit = function(t, e) {
        if ("string" != typeof t && "number" != typeof t) return "";
        var n = "";
        e = e || 2;
        for (var o = (t = String(t)).length; o < e; o++) n += "0";
        return t < Math.pow(10, e) ? n + t : t
    }, h.elem = function(t, e) {
        var n = f.createElement(t);
        return h.each(e || {}, function(t, e) {
            n.setAttribute(t, e)
        }), n
    }, h.hasScrollbar = function() {
        return f.body.scrollHeight > (l.innerHeight || f.documentElement.clientHeight)
    }, h.position = function(t, e, n) {
        var o, r, i, c, u, a, s;
        e && (n = n || {}, t !== f && t !== h("body")[0] || (n.clickType = "right"), u = "right" === n.clickType ? {
            left: (u = n.e || l.event || {}).clientX,
            top: u.clientY,
            right: u.clientX,
            bottom: u.clientY
        } : t.getBoundingClientRect(), a = e.offsetWidth, s = e.offsetHeight, o = function(t) {
            return f.body[t = t ? "scrollLeft" : "scrollTop"] | f.documentElement[t]
        }, i = u.left, c = u.bottom, "center" === n.align ? i -= (a - t.offsetWidth) / 2 : "right" === n.align && (i = i - a + t.offsetWidth), (i = i + a + 5 > (r = function(t) {
            return f.documentElement[t ? "clientWidth" : "clientHeight"]
        })("width") ? r("width") - a - 5 : i) < 5 && (i = 5), c + s + 5 > r() && (u.top > s + 5 ? c = u.top - s - 10 : "right" === n.clickType ? (c = r() - s - 10) < 0 && (c = 0) : c = 5), (a = n.position) && (e.style.position = a), e.style.left = i + ("fixed" === a ? 0 : o(1)) + "px", e.style.top = c + ("fixed" === a ? 0 : o()) + "px", h.hasScrollbar() || (s = e.getBoundingClientRect(), !n.SYSTEM_RELOAD && s.bottom + 5 > r() && (n.SYSTEM_RELOAD = !0, setTimeout(function() {
            h.position(t, e, n)
        }, 50))))
    }, h.options = function(t, e) {
        e = "object" == typeof e ? e : {
            attr: e
        };
        var t = h(t),
            n = e.attr || "lay-options";
        try {
            return new Function("return " + (t.attr(n) || "{}"))()
        } catch (o) {
            return hint.error(e.errorText || "parseerror: " + o, "error"), {}
        }
    }, h.isTopElem = function(n) {
        var t = [f, h("body")[0]],
            o = !1;
        return h.each(t, function(t, e) {
            if (e === n) return o = !0
        }), o
    }, r.addStr = function(n, t) {
        return n = n.replace(/\s+/, " "), t = t.replace(/\s+/, " ").split(" "), h.each(t, function(t, e) {
            new RegExp("\\b" + e + "\\b").test(n) || (n = n + " " + e)
        }), n.replace(/^\s|\s$/, "")
    }, r.removeStr = function(n, t) {
        return n = n.replace(/\s+/, " "), t = t.replace(/\s+/, " ").split(" "), h.each(t, function(t, e) {
            e = new RegExp("\\b" + e + "\\b");
            e.test(n) && (n = n.replace(e, ""))
        }), n.replace(/\s+/, " ").replace(/^\s|\s$/, "")
    }, r.prototype.find = function(o) {
        var r = this,
            i = 0,
            c = [],
            u = "object" == typeof o;
        return this.each(function(t, e) {
            for (var n = u ? e.contains(o) : e.querySelectorAll(o || null); i < n.length; i++) c.push(n[i]);
            r.shift()
        }), u || (r.selector = (r.selector ? r.selector + " " : "") + o), h.each(c, function(t, e) {
            r.push(e)
        }), r
    }, r.prototype.each = function(t) {
        return h.each.call(this, this, t)
    }, r.prototype.addClass = function(n, o) {
        return this.each(function(t, e) {
            e.className = r[o ? "removeStr" : "addStr"](e.className, n)
        })
    }, r.prototype.removeClass = function(t) {
        return this.addClass(t, !0)
    }, r.prototype.hasClass = function(n) {
        var o = !1;
        return this.each(function(t, e) {
            new RegExp("\\b" + n + "\\b").test(e.className) && (o = !0)
        }), o
    }, r.prototype.css = function(e, o) {
        var t = this,
            r = function(t) {
                return isNaN(t) ? t : t + "px"
            };
        return "string" != typeof e || o !== undefined ? t.each(function(t, n) {
            "object" == typeof e ? h.each(e, function(t, e) {
                n.style[t] = r(e)
            }) : n.style[e] = r(o)
        }) : 0 < t.length ? t[0].style[e] : void 0
    }, r.prototype.width = function(n) {
        var o = this;
        return n !== undefined ? o.each(function(t, e) {
            o.css("width", n)
        }) : 0 < o.length ? o[0].offsetWidth : void 0
    }, r.prototype.height = function(n) {
        var o = this;
        return n !== undefined ? o.each(function(t, e) {
            o.css("height", n)
        }) : 0 < o.length ? o[0].offsetHeight : void 0
    }, r.prototype.attr = function(n, o) {
        var t = this;
        return o !== undefined ? t.each(function(t, e) {
            e.setAttribute(n, o)
        }) : 0 < t.length ? t[0].getAttribute(n) : void 0
    }, r.prototype.removeAttr = function(n) {
        return this.each(function(t, e) {
            e.removeAttribute(n)
        })
    }, r.prototype.html = function(n) {
        var t = this;
        return n !== undefined ? this.each(function(t, e) {
            e.innerHTML = n
        }) : 0 < t.length ? t[0].innerHTML : void 0
    }, r.prototype.val = function(n) {
        var t = this;
        return n !== undefined ? this.each(function(t, e) {
            e.value = n
        }) : 0 < t.length ? t[0].value : void 0
    }, r.prototype.append = function(n) {
        return this.each(function(t, e) {
            "object" == typeof n ? e.appendChild(n) : e.innerHTML = e.innerHTML + n
        })
    }, r.prototype.remove = function(n) {
        return this.each(function(t, e) {
            n ? e.removeChild(n) : e.parentNode.removeChild(e)
        })
    }, r.prototype.on = function(n, o) {
        return this.each(function(t, e) {
            e.attachEvent ? e.attachEvent("on" + n, function(t) {
                t.target = t.srcElement, o.call(e, t)
            }) : e.addEventListener(n, o, !1)
        })
    }, r.prototype.off = function(n, o) {
        return this.each(function(t, e) {
            e.detachEvent ? e.detachEvent("on" + n, o) : e.removeEventListener(n, o, !1)
        })
    }, l.lay = h, l.layui && layui.define && layui.define(function(t) {
        t("lay", h)
    })
}(window, window.document);
layui.define(function(e) {
    "use strict";
    var n = document,
        u = "getElementById",
        c = "getElementsByTagName",
        a = "layui-disabled",
        t = function(e) {
            var a = this;
            a.config = e || {}, a.config.index = ++o.index, a.render(!0)
        },
        o = (t.prototype.type = function() {
            var e = this.config;
            if ("object" == typeof e.elem) return e.elem.length === undefined ? 2 : 3
        }, t.prototype.view = function() {
            var t, i, r = this.config,
                n = r.groups = "groups" in r ? Number(r.groups) || 0 : 5,
                u = (r.layout = "object" == typeof r.layout ? r.layout : ["prev", "page", "next"], r.count = Number(r.count) || 0, r.curr = Number(r.curr) || 1, r.limits = "object" == typeof r.limits ? r.limits : [10, 20, 30, 40, 50], r.limit = Number(r.limit) || 10, r.pages = Math.ceil(r.count / r.limit) || 1, r.curr > r.pages ? r.curr = r.pages : r.curr < 1 && (r.curr = 1), n < 0 ? n = 1 : n > r.pages && (n = r.pages), r.prev = "prev" in r ? r.prev : "&#x4E0A;&#x4E00;&#x9875;", r.next = "next" in r ? r.next : "&#x4E0B;&#x4E00;&#x9875;", r.pages > n ? Math.ceil((r.curr + (1 < n ? 1 : 0)) / (0 < n ? n : 1)) : 1),
                s = {
                    prev: r.prev ? '<a href="javascript:;" class="layui-laypage-prev' + (1 == r.curr ? " " + a : "") + '" data-page="' + (r.curr - 1) + '">' + r.prev + "</a>" : "",
                    page: function() {
                        var e = [];
                        if (r.count < 1) return "";
                        1 < u && !1 !== r.first && 0 !== n && e.push('<a href="javascript:;" class="layui-laypage-first" data-page="1"  title="&#x9996;&#x9875;">' + (r.first || 1) + "</a>");
                        var a = Math.floor((n - 1) / 2),
                            t = 1 < u ? r.curr - a : 1,
                            i = 1 < u ? (a = r.curr + (n - a - 1)) > r.pages ? r.pages : a : n;
                        for (i - t < n - 1 && (t = i - n + 1), !1 !== r.first && 2 < t && e.push('<span class="layui-laypage-spr">&#x2026;</span>'); t <= i; t++) t === r.curr ? e.push('<span class="layui-laypage-curr"><em class="layui-laypage-em" ' + (/^#/.test(r.theme) ? 'style="background-color:' + r.theme + ';"' : "") + "></em><em>" + t + "</em></span>") : e.push('<a href="javascript:;" data-page="' + t + '">' + t + "</a>");
                        return r.pages > n && r.pages > i && !1 !== r.last && (i + 1 < r.pages && e.push('<span class="layui-laypage-spr">&#x2026;</span>'), 0 !== n && e.push('<a href="javascript:;" class="layui-laypage-last" title="&#x5C3E;&#x9875;"  data-page="' + r.pages + '">' + (r.last || r.pages) + "</a>")), e.join("")
                    }(),
                    next: r.next ? '<a href="javascript:;" class="layui-laypage-next' + (r.curr == r.pages ? " " + a : "") + '" data-page="' + (r.curr + 1) + '">' + r.next + "</a>" : "",
                    count: '<span class="layui-laypage-count">\u5171 ' + r.count + " \u6761</span>",
                    limit: (t = ['<span class="layui-laypage-limits"><select lay-ignore>'], layui.each(r.limits, function(e, a) {
                        t.push('<option value="' + a + '"' + (a === r.limit ? "selected" : "") + ">" + a + " \u6761/\u9875</option>")
                    }), t.join("") + "</select></span>"),
                    refresh: ['<a href="javascript:;" data-page="' + r.curr + '" class="layui-laypage-refresh">', '<i class="layui-icon layui-icon-refresh"></i>', "</a>"].join(""),
                    skip: ['<span class="layui-laypage-skip">&#x5230;&#x7B2C;', '<input type="text" min="1" value="' + r.curr + '" class="layui-input">', '&#x9875;<button type="button" class="layui-laypage-btn">&#x786e;&#x5b9a;</button>', "</span>"].join("")
                };
            return ['<div class="layui-box layui-laypage layui-laypage-' + (r.theme ? /^#/.test(r.theme) ? "molv" : r.theme : "default") + '" id="layui-laypage-' + r.index + '">', (i = [], layui.each(r.layout, function(e, a) {
                s[a] && i.push(s[a])
            }), i.join("")), "</div>"].join("")
        }, t.prototype.jump = function(e, a) {
            if (e) {
                var t = this,
                    i = t.config,
                    r = e.children,
                    n = e[c]("button")[0],
                    u = e[c]("input")[0],
                    e = e[c]("select")[0],
                    s = function() {
                        var e = Number(u.value.replace(/\s|\D/g, ""));
                        e && (i.curr = e, t.render())
                    };
                if (a) return s();
                for (var l = 0, p = r.length; l < p; l++)"a" === r[l].nodeName.toLowerCase() && o.on(r[l], "click", function() {
                    var e = Number(this.getAttribute("data-page"));
                    e < 1 || e > i.pages || (i.curr = e, t.render())
                });
                e && o.on(e, "change", function() {
                    var e = this.value;
                    i.curr * e > i.count && (i.curr = Math.ceil(i.count / e)), i.limit = e, t.render()
                }), n && o.on(n, "click", function() {
                    s()
                })
            }
        }, t.prototype.skip = function(t) {
            var i, e;
            t && (i = this, (e = t[c]("input")[0]) && o.on(e, "keyup", function(e) {
                var a = this.value,
                    e = e.keyCode;
                /^(37|38|39|40)$/.test(e) || (/\D/.test(a) && (this.value = a.replace(/\D/, "")), 13 === e && i.jump(t, !0))
            }))
        }, t.prototype.render = function(e) {
            var a = this,
                t = a.config,
                i = a.type(),
                r = a.view(),
                i = (2 === i ? t.elem && (t.elem.innerHTML = r) : 3 === i ? t.elem.html(r) : n[u](t.elem) && (n[u](t.elem).innerHTML = r), t.jump && t.jump(t, e), n[u]("layui-laypage-" + t.index));
            a.jump(i), t.hash && !e && (location.hash = "!" + t.hash + "=" + t.curr), a.skip(i)
        }, {
            render: function(e) {
                return new t(e).index
            },
            index: layui.laypage ? layui.laypage.index + 1e4 : 0,
            on: function(a, e, t) {
                return a.attachEvent ? a.attachEvent("on" + e, function(e) {
                    e.target = e.srcElement, t.call(a, e)
                }) : a.addEventListener(e, t, !1), this
            }
        });
    e("laypage", o)
});
!
function(i, f) {
    "use strict";
    var n = i.layui && layui.define,
        l = {
            getPath: i.lay && lay.getPath ? lay.getPath : "",
            link: function(e, t, a) {
                p.path && i.lay && lay.layui && lay.layui.link(p.path + e, t, a)
            }
        },
        e = i.LAYUI_GLOBAL || {},
        p = {
            v: "5.4.0",
            config: {
                weekStart: 0
            },
            index: i.laydate && i.laydate.v ? 1e5 : 0,
            path: e.laydate_dir || l.getPath,
            set: function(e) {
                var t = this;
                return t.config = lay.extend({}, t.config, e), t
            },
            ready: function(e) {
                var t = "laydate",
                    a = (n ? "modules/" : "css/") + "laydate.css?v=" + p.v;
                return n ? layui["layui.all"] ? "function" == typeof e && e() : layui.addcss(a, e, t) : l.link(a, e, t), this
            }
        },
        s = function() {
            var t = this,
                e = t.config.id;
            return (s.that[e] = t).inst = {
                hint: function(e) {
                    t.hint.call(t, e)
                },
                config: t.config
            }
        },
        a = "laydate",
        x = "layui-this",
        w = "laydate-disabled",
        h = [100, 2e5],
        g = "layui-laydate-static",
        M = "layui-laydate-list",
        r = "layui-laydate-hint",
        E = ".laydate-btns-confirm",
        C = "laydate-time-text",
        k = "laydate-btns-time",
        v = "layui-laydate-preview",
        T = function(e) {
            var t = this,
                a = (t.index = ++p.index, t.config = lay.extend({}, t.config, p.config, e), lay(e.elem || t.config.elem));
            if (1 < a.length) return lay.each(a, function() {
                p.render(lay.extend({}, t.config, lay.options(this), {
                    elem: this
                }))
            }), t;
            (e = t.config).id = "id" in e ? e.id : t.index, p.ready(function() {
                t.init()
            })
        },
        y = "yyyy|y|MM|M|dd|d|HH|H|mm|m|ss|s";
    s.formatArr = function(e) {
        return (e || "").match(new RegExp(y + "|.", "g")) || []
    }, T.isLeapYear = function(e) {
        return e % 4 == 0 && e % 100 != 0 || e % 400 == 0
    }, T.prototype.config = {
        type: "date",
        range: !1,
        format: "yyyy-MM-dd",
        value: null,
        isInitValue: !0,
        min: "1900-1-1",
        max: "2099-12-31",
        trigger: "click",
        show: !1,
        showBottom: !0,
        isPreview: !0,
        btns: ["clear", "now", "confirm"],
        lang: "cn",
        theme: "default",
        position: null,
        calendar: !1,
        mark: {},
        holidays: null,
        zIndex: null,
        done: null,
        change: null
    }, T.prototype.lang = function() {
        var e = {
            cn: {
                weeks: ["\u65e5", "\u4e00", "\u4e8c", "\u4e09", "\u56db", "\u4e94", "\u516d"],
                time: ["\u65f6", "\u5206", "\u79d2"],
                timeTips: "\u9009\u62e9\u65f6\u95f4",
                startTime: "\u5f00\u59cb\u65f6\u95f4",
                endTime: "\u7ed3\u675f\u65f6\u95f4",
                dateTips: "\u8fd4\u56de\u65e5\u671f",
                month: ["\u4e00", "\u4e8c", "\u4e09", "\u56db", "\u4e94", "\u516d", "\u4e03", "\u516b", "\u4e5d", "\u5341", "\u5341\u4e00", "\u5341\u4e8c"],
                tools: {
                    confirm: "\u786e\u5b9a",
                    clear: "\u6e05\u7a7a",
                    now: "\u73b0\u5728"
                },
                timeout: "\u7ed3\u675f\u65f6\u95f4\u4e0d\u80fd\u65e9\u4e8e\u5f00\u59cb\u65f6\u95f4<br>\u8bf7\u91cd\u65b0\u9009\u62e9",
                invalidDate: "\u4e0d\u5728\u6709\u6548\u65e5\u671f\u6216\u65f6\u95f4\u8303\u56f4\u5185",
                formatError: ["\u65e5\u671f\u683c\u5f0f\u4e0d\u5408\u6cd5<br>\u5fc5\u987b\u9075\u5faa\u4e0b\u8ff0\u683c\u5f0f\uff1a<br>", "<br>\u5df2\u4e3a\u4f60\u91cd\u7f6e"],
                preview: "\u5f53\u524d\u9009\u4e2d\u7684\u7ed3\u679c"
            },
            en: {
                weeks: ["Su", "Mo", "Tu", "We", "Th", "Fr", "Sa"],
                time: ["Hours", "Minutes", "Seconds"],
                timeTips: "Select Time",
                startTime: "Start Time",
                endTime: "End Time",
                dateTips: "Select Date",
                month: ["Jan", "Feb", "Mar", "Apr", "May", "Jun", "Jul", "Aug", "Sep", "Oct", "Nov", "Dec"],
                tools: {
                    confirm: "Confirm",
                    clear: "Clear",
                    now: "Now"
                },
                timeout: "End time cannot be less than start Time<br>Please re-select",
                invalidDate: "Invalid date",
                formatError: ["The date format error<br>Must be followed\uff1a<br>", "<br>It has been reset"],
                preview: "The selected result"
            }
        };
        return e[this.config.lang] || e.cn
    }, T.prototype.init = function() {
        var e, r = this,
            o = r.config,
            t = "static" === o.position,
            a = {
                year: "yyyy",
                month: "yyyy-MM",
                date: "yyyy-MM-dd",
                time: "HH:mm:ss",
                datetime: "yyyy-MM-dd HH:mm:ss"
            };
        o.elem = lay(o.elem), o.eventElem = lay(o.eventElem), o.elem[0] && ((e = s.that[o.elem.attr("lay-key")]) && e.destroy && e.destroy(), "array" !== layui.type(o.theme) && (o.theme = [o.theme]), o.fullPanel && ("datetime" !== o.type || o.range) && delete o.fullPanel, r.rangeStr = o.range ? "string" == typeof o.range ? o.range : "-" : "", "array" === layui.type(o.range) && (r.rangeElem = [lay(o.range[0]), lay(o.range[1])]), a[o.type] || (i.console && console.error && console.error("laydate type error:'" + o.type + "' is not supported"), o.type = "date"), o.format === a.date && (o.format = a[o.type] || a.date), r.format = s.formatArr(o.format), o.weekStart && !/^[0-6]$/.test(o.weekStart) && (e = r.lang(), o.weekStart = e.weeks.indexOf(o.weekStart), -1 === o.weekStart && (o.weekStart = 0)), r.EXP_IF = "", r.EXP_SPLIT = "", lay.each(r.format, function(e, t) {
            e = new RegExp(y).test(t) ? "\\d{" + (new RegExp(y).test(r.format[0 === e ? e + 1 : e - 1] || "") ? /^yyyy|y$/.test(t) ? 4 : t.length : /^yyyy$/.test(t) ? "1,4" : /^y$/.test(t) ? "1,308" : "1,2") + "}" : "\\" + t;
            r.EXP_IF = r.EXP_IF + e, r.EXP_SPLIT = r.EXP_SPLIT + "(" + e + ")"
        }), r.EXP_IF_ONE = new RegExp("^" + r.EXP_IF + "$"), r.EXP_IF = new RegExp("^" + (o.range ? r.EXP_IF + "\\s\\" + r.rangeStr + "\\s" + r.EXP_IF : r.EXP_IF) + "$"), r.EXP_SPLIT = new RegExp("^" + r.EXP_SPLIT + "$", ""), r.isInput(o.elem[0]) || "focus" === o.trigger && (o.trigger = "click"), o.elem.attr("lay-key", r.index), o.eventElem.attr("lay-key", r.index), o.mark = lay.extend({}, o.calendar && "cn" === o.lang ? {
            "0-1-1": "\u5143\u65e6",
            "0-2-14": "\u60c5\u4eba",
            "0-3-8": "\u5987\u5973",
            "0-3-12": "\u690d\u6811",
            "0-4-1": "\u611a\u4eba",
            "0-5-1": "\u52b3\u52a8",
            "0-5-4": "\u9752\u5e74",
            "0-6-1": "\u513f\u7ae5",
            "0-9-10": "\u6559\u5e08",
            "0-10-1": "\u56fd\u5e86",
            "0-12-25": "\u5723\u8bde"
        } : {}, o.mark), lay.each(["min", "max"], function(e, t) {
            var a, n, i = [],
                l = [];
            l = "number" == typeof o[t] ? (a = o[t], n = new Date, n = r.newDate({
                year: n.getFullYear(),
                month: n.getMonth(),
                date: n.getDate(),
                hours: e ? 23 : 0,
                minutes: e ? 59 : 0,
                seconds: e ? 59 : 0
            }).getTime(), i = [(e = new Date(a ? a < 864e5 ? n + 864e5 * a : a : n)).getFullYear(), e.getMonth() + 1, e.getDate()], [e.getHours(), e.getMinutes(), e.getSeconds()]) : (i = (o[t].match(/\d+-\d+-\d+/) || [""])[0].split("-"), (o[t].match(/\d+:\d+:\d+/) || [""])[0].split(":")), o[t] = {
                year: 0 | i[0] || (new Date).getFullYear(),
                month: i[1] ? (0 | i[1]) - 1 : (new Date).getMonth(),
                date: 0 | i[2] || (new Date).getDate(),
                hours: 0 | l[0],
                minutes: 0 | l[1],
                seconds: 0 | l[2]
            }
        }), r.elemID = "layui-laydate" + o.elem.attr("lay-key"), (o.show || t) && r.render(), t || r.events(), o.value && o.isInitValue && ("date" === layui.type(o.value) ? r.setValue(r.parse(0, r.systemDate(o.value))) : r.setValue(o.value)))
    }, T.prototype.render = function() {
        var a, e, n, i, l = this,
            o = l.config,
            s = l.lang(),
            r = "static" === o.position,
            y = l.elem = lay.elem("div", {
                id: l.elemID,
                "class": ["layui-laydate", o.range ? " layui-laydate-range" : "", r ? " " + g : "", o.fullPanel ? " laydate-theme-fullpanel" : "", (a = "", lay.each(o.theme, function(e, t) {
                    "default" === t || /^#/.test(t) || (a += " laydate-theme-" + t)
                }), a)].join("")
            }),
            d = l.elemMain = [],
            m = l.elemHeader = [],
            c = l.elemCont = [],
            u = l.table = [],
            t = l.footer = lay.elem("div", {
                "class": "layui-laydate-footer"
            }),
            h = (o.zIndex && (y.style.zIndex = o.zIndex), lay.each(new Array(2), function(e) {
                if (!o.range && 0 < e) return !0;
                var a = lay.elem("div", {
                    "class": "layui-laydate-header"
                }),
                    t = [((t = lay.elem("i", {
                        "class": "layui-icon laydate-icon laydate-prev-y"
                    })).innerHTML = "&#xe65a;", t), ((t = lay.elem("i", {
                        "class": "layui-icon laydate-icon laydate-prev-m"
                    })).innerHTML = "&#xe603;", t), (t = lay.elem("div", {
                        "class": "laydate-set-ym"
                    }), n = lay.elem("span"), l = lay.elem("span"), t.appendChild(n), t.appendChild(l), t), ((n = lay.elem("i", {
                        "class": "layui-icon laydate-icon laydate-next-m"
                    })).innerHTML = "&#xe602;", n), ((l = lay.elem("i", {
                        "class": "layui-icon laydate-icon laydate-next-y"
                    })).innerHTML = "&#xe65b;", l)],
                    n = lay.elem("div", {
                        "class": "layui-laydate-content"
                    }),
                    i = lay.elem("table"),
                    l = lay.elem("thead"),
                    r = lay.elem("tr");
                lay.each(t, function(e, t) {
                    a.appendChild(t)
                }), l.appendChild(r), lay.each(new Array(6), function(a) {
                    var n = i.insertRow(0);
                    lay.each(new Array(7), function(e) {
                        var t;
                        0 === a && ((t = lay.elem("th")).innerHTML = s.weeks[(e + o.weekStart) % 7], r.appendChild(t)), n.insertCell(e)
                    })
                }), i.insertBefore(l, i.children[0]), n.appendChild(i), d[e] = lay.elem("div", {
                    "class": "layui-laydate-main laydate-main-list-" + e
                }), d[e].appendChild(a), d[e].appendChild(n), m.push(t), c.push(n), u.push(i)
            }), lay(t).html((e = [], n = [], "datetime" === o.type && e.push('<span lay-type="datetime" class="' + k + '">' + s.timeTips + "</span>"), (o.range || "datetime" !== o.type || o.fullPanel) && e.push('<span class="' + v + '" title="' + s.preview + '"></span>'), lay.each(o.btns, function(e, t) {
                var a = s.tools[t] || "btn";
                o.range && "now" === t || (r && "clear" === t && (a = "cn" === o.lang ? "\u91cd\u7f6e" : "Reset"), n.push('<span lay-type="' + t + '" class="laydate-btns-' + t + '">' + a + "</span>"))
            }), e.push('<div class="laydate-footer-btns">' + n.join("") + "</div>"), e.join(""))), lay.each(d, function(e, t) {
                y.appendChild(t)
            }), o.showBottom && y.appendChild(t), []);
        lay.each(o.theme, function(e, t) {
            /^#/.test(t) && (i = i || lay.elem("style"), h.push(["#{{id}} .layui-laydate-header{background-color:{{theme}};}", "#{{id}} li.layui-this,#{{id}} td.layui-this>div{background-color:{{theme}} !important;}", -1 !== o.theme.indexOf("circle") ? "" : "#{{id}} .layui-this{background-color:{{theme}} !important;}"].join("").replace(/{{id}}/g, l.elemID).replace(/{{theme}}/g, t)))
        }), i && (h = h.join(""), "styleSheet" in i ? (i.setAttribute("type", "text/css"), i.styleSheet.cssText = h) : i.innerHTML = h, lay(y).addClass("laydate-theme-molv"), y.appendChild(i)), l.remove(T.thisElemDate), p.thisId = o.id, r ? o.elem.append(y) : (f.body.appendChild(y), l.position()), l.checkDate().calendar(null, 0, "init"), l.changeEvent(), T.thisElemDate = l.elemID, l.renderAdditional(), "function" == typeof o.ready && o.ready(lay.extend({}, o.dateTime, {
            month: o.dateTime.month + 1
        })), l.preview()
    }, T.prototype.remove = function(e) {
        var t = this,
            a = t.config,
            n = lay("#" + (e || t.elemID));
        return n[0] && (n.hasClass(g) || t.checkDate(function() {
            n.remove(), delete p.thisId, "function" == typeof a.close && a.close(t)
        })), t
    }, T.prototype.position = function() {
        var e = this.config;
        return lay.position(this.bindElem || e.elem[0], this.elem, {
            position: e.position
        }), this
    }, T.prototype.hint = function(e) {
        var t = this,
            a = (t.config, lay.elem("div", {
                "class": r
            }));
        t.elem && (a.innerHTML = e || "", lay(t.elem).find("." + r).remove(), t.elem.appendChild(a), clearTimeout(t.hinTimer), t.hinTimer = setTimeout(function() {
            lay(t.elem).find("." + r).remove()
        }, 3e3))
    }, T.prototype.getAsYM = function(e, t, a) {
        return a ? t-- : t++, t < 0 && (t = 11, e--), 11 < t && (t = 0, e++), [e, t]
    }, T.prototype.systemDate = function(e) {
        var t = e || new Date;
        return {
            year: t.getFullYear(),
            month: t.getMonth(),
            date: t.getDate(),
            hours: e ? e.getHours() : 0,
            minutes: e ? e.getMinutes() : 0,
            seconds: e ? e.getSeconds() : 0
        }
    }, T.prototype.checkDate = function(e) {
        var t, o, s = this,
            y = (new Date, s.config),
            a = s.lang(),
            n = y.dateTime = y.dateTime || s.systemDate(),
            i = s.bindElem || y.elem[0],
            l = (s.isInput(i), function() {
                if (s.rangeElem) {
                    var e = [s.rangeElem[0].val(), s.rangeElem[1].val()];
                    if (e[0] && e[1]) return e.join(" " + s.rangeStr + " ")
                }
                return s.isInput(i) ? i.value : "static" === y.position ? "" : lay(i).attr("lay-date")
            }()),
            d = function(e) {
                e.year > h[1] && (e.year = h[1], o = !0), 11 < e.month && (e.month = 11, o = !0), 59 < e.seconds && (e.seconds = 0, e.minutes++, o = !0), 59 < e.minutes && (e.minutes = 0, e.hours++, o = !0), 23 < e.hours && (e.hours = 0, o = !0), t = p.getEndDate(e.month + 1, e.year), e.date > t && (e.date = t, o = !0)
            },
            r = function(n, i, l) {
                var r = ["startTime", "endTime"];
                i = (i.match(s.EXP_SPLIT) || []).slice(1), l = l || 0, y.range && (s[r[l]] = s[r[l]] || {}), lay.each(s.format, function(e, t) {
                    var a = parseFloat(i[e]);
                    i[e].length < t.length && (o = !0), /yyyy|y/.test(t) ? (a < h[0] && (a = h[0], o = !0), n.year = a) : /MM|M/.test(t) ? (a < 1 && (a = 1, o = !0), n.month = a - 1) : /dd|d/.test(t) ? (a < 1 && (a = 1, o = !0), n.date = a) : /HH|H/.test(t) ? (a < 0 && (o = !(a = 0)), 23 < a && (a = 23, o = !0), n.hours = a, y.range && (s[r[l]].hours = a)) : /mm|m/.test(t) ? (a < 0 && (o = !(a = 0)), 59 < a && (a = 59, o = !0), n.minutes = a, y.range && (s[r[l]].minutes = a)) : /ss|s/.test(t) && (a < 0 && (o = !(a = 0)), 59 < a && (a = 59, o = !0), n.seconds = a, y.range && (s[r[l]].seconds = a))
                }), d(n)
            };
        if ("limit" === e) return d(n), s;
        "string" == typeof(l = l || y.value) && (l = l.replace(/\s+/g, " ").replace(/^\s|\s$/g, ""));
        var m, c, u = function() {
                var e, t, a;
                y.range && (s.endDate = s.endDate || lay.extend({}, y.dateTime, (e = {}, t = y.dateTime, a = s.getAsYM(t.year, t.month), "year" === y.type ? e.year = t.year + 1 : "time" !== y.type && (e.year = a[0], e.month = a[1]), "datetime" !== y.type && "time" !== y.type || (e.hours = 23, e.minutes = e.seconds = 59), e)))
            };
        return u(), "string" == typeof l && l ? s.EXP_IF.test(l) ? y.range ? (l = l.split(" " + s.rangeStr + " "), lay.each([y.dateTime, s.endDate], function(e, t) {
            r(t, l[e], e)
        })) : r(n, l) : (s.hint(a.formatError[0] + (y.range ? y.format + " " + s.rangeStr + " " + y.format : y.format) + a.formatError[1]), o = !0) : l && "date" === layui.type(l) ? y.dateTime = s.systemDate(l) : (y.dateTime = s.systemDate(), delete s.startTime, delete s.endDate, u(), delete s.endTime), s.rangeElem && (u = [s.rangeElem[0].val(), s.rangeElem[1].val()], m = [y.dateTime, s.endDate], lay.each(u, function(e, t) {
            s.EXP_IF_ONE.test(t) && r(m[e], t, e)
        })), d(n), y.range && d(s.endDate), o && l && s.setValue(!y.range || s.endDate ? s.parse() : ""), s.getDateTime(n) > s.getDateTime(y.max) ? (n = y.dateTime = lay.extend({}, y.max), c = !0) : s.getDateTime(n) < s.getDateTime(y.min) && (n = y.dateTime = lay.extend({}, y.min), c = !0), y.range && ((s.getDateTime(s.endDate) < s.getDateTime(y.min) || s.getDateTime(s.endDate) > s.getDateTime(y.max)) && (s.endDate = lay.extend({}, y.max), c = !0), s.startTime = {
            hours: y.dateTime.hours,
            minutes: y.dateTime.minutes,
            seconds: y.dateTime.seconds
        }, s.endTime = {
            hours: s.endDate.hours,
            minutes: s.endDate.minutes,
            seconds: s.endDate.seconds
        }), c && l && (s.setValue(s.parse()), s.hint("value " + a.invalidDate + a.formatError[1])), e && e(), s
    }, T.prototype.mark = function(e, a) {
        var n, t = this.config;
        return lay.each(t.mark, function(e, t) {
            e = e.split("-");
            e[0] != a[0] && 0 != e[0] || e[1] != a[1] && 0 != e[1] || e[2] != a[2] || (n = t || a[2])
        }), n && e.find("div").html('<span class="laydate-day-mark">' + n + "</span>"), this
    }, T.prototype.holidays = function(n, i) {
        var e = this.config,
            l = ["", "work"];
        return "array" !== layui.type(e.holidays) || lay.each(e.holidays, function(a, e) {
            lay.each(e, function(e, t) {
                t === n.attr("lay-ymd") && n.find("div").html('<span class="laydate-day-holidays"' + (l[a] ? 'type="' + l[a] + '"' : "") + ">" + i[2] + "</span>")
            })
        }), this
    }, T.prototype.limit = function(t) {
        t = t || {};
        var i = this,
            e = i.config,
            l = {},
            a = t.index > (t.time ? 0 : 41) ? i.endDate : e.dateTime,
            a = lay.extend({}, a, t.date || {});
        return lay.each({
            now: a,
            min: e.min,
            max: e.max
        }, function(e, a) {
            var n;
            l[e] = i.newDate(lay.extend({
                year: a.year,
                month: "year" === t.type ? 0 : a.month,
                date: "year" === t.type || "month" === t.type ? 1 : a.date
            }, (n = {}, lay.each(t.time, function(e, t) {
                n[t] = a[t]
            }), n))).getTime()
        }), a = l.now < l.min || l.now > l.max, t.elem && t.elem[a ? "addClass" : "removeClass"](w), a
    }, T.prototype.thisDateTime = function(e) {
        var t = this.config;
        return e ? this.endDate : t.dateTime
    }, T.prototype.calendar = function(e, t, a) {
        var i, l, r, o = this,
            n = o.config,
            t = t ? 1 : 0,
            s = e || o.thisDateTime(t),
            y = new Date,
            d = o.lang(),
            m = "date" !== n.type && "datetime" !== n.type,
            c = lay(o.table[t]).find("td"),
            t = lay(o.elemHeader[t][2]).find("span");
        return s.year < h[0] && (s.year = h[0], o.hint(d.invalidDate)), s.year > h[1] && (s.year = h[1], o.hint(d.invalidDate)), o.firstDate || (o.firstDate = lay.extend({}, s)), y.setFullYear(s.year, s.month, 1), i = (y.getDay() + (7 - n.weekStart)) % 7, l = p.getEndDate(s.month || 12, s.year), r = p.getEndDate(s.month + 1, s.year), lay.each(c, function(e, t) {
            var a = [s.year, s.month],
                n = 0;
            (t = lay(t)).removeAttr("class"), e < i ? (n = l - i + e, t.addClass("laydate-day-prev"), a = o.getAsYM(s.year, s.month, "sub")) : i <= e && e < r + i ? (n = e - i) + 1 === s.date && t.addClass(x) : (n = e - r - i, t.addClass("laydate-day-next"), a = o.getAsYM(s.year, s.month)), a[1]++, a[2] = n + 1, t.attr("lay-ymd", a.join("-")).html("<div>" + a[2] + "</div>"), o.mark(t, a).holidays(t, a).limit({
                elem: t,
                date: {
                    year: a[0],
                    month: a[1] - 1,
                    date: a[2]
                },
                index: e
            })
        }), lay(t[0]).attr("lay-ym", s.year + "-" + (s.month + 1)), lay(t[1]).attr("lay-ym", s.year + "-" + (s.month + 1)), "cn" === n.lang ? (lay(t[0]).attr("lay-type", "year").html(s.year + " \u5e74"), lay(t[1]).attr("lay-type", "month").html(s.month + 1 + " \u6708")) : (lay(t[0]).attr("lay-type", "month").html(d.month[s.month]), lay(t[1]).attr("lay-type", "year").html(s.year)), m && (n.range ? e && (o.listYM = [
            [n.dateTime.year, n.dateTime.month + 1],
            [o.endDate.year, o.endDate.month + 1]
        ], o.list(n.type, 0).list(n.type, 1), "time" === n.type ? o.setBtnStatus("\u65f6\u95f4", lay.extend({}, o.systemDate(), o.startTime), lay.extend({}, o.systemDate(), o.endTime)) : o.setBtnStatus(!0)) : (o.listYM = [
            [s.year, s.month + 1]
        ], o.list(n.type, 0))), n.range && "init" === a && !e && o.calendar(o.endDate, 1), n.range || (y = ["hours", "minutes", "seconds"], o.limit({
            elem: lay(o.footer).find(".laydate-btns-now"),
            date: o.systemDate(),
            index: 0,
            time: y
        }), o.limit({
            elem: lay(o.footer).find(E),
            index: 0,
            time: y
        })), o.setBtnStatus(), o
    }, T.prototype.list = function(n, i) {
        var l, r, e, o, s = this,
            y = s.config,
            d = y.dateTime,
            m = s.lang(),
            t = y.range && "date" !== y.type && "datetime" !== y.type,
            c = lay.elem("ul", {
                "class": M + " " + {
                    year: "laydate-year-list",
                    month: "laydate-month-list",
                    time: "laydate-time-list"
                }[n]
            }),
            a = s.elemHeader[i],
            u = lay(a[2]).find("span"),
            h = s.elemCont[i || 0],
            f = lay(h).find("." + M)[0],
            p = "cn" === y.lang,
            g = p ? "\u5e74" : "",
            v = s.listYM[i] || {},
            T = ["hours", "minutes", "seconds"],
            D = ["startTime", "endTime"][i];
        return v[0] < 1 && (v[0] = 1), "year" === n ? (e = l = v[0] - 7, l < 1 && (e = l = 1), lay.each(new Array(15), function(e) {
            var t = lay.elem("li", {
                "lay-ym": l
            }),
                a = {
                    year: l,
                    month: 0,
                    date: 1
                };
            l == v[0] && lay(t).addClass(x), t.innerHTML = l + g, c.appendChild(t), s.limit({
                elem: lay(t),
                date: a,
                index: i,
                type: n
            }), l++
        }), lay(u[p ? 0 : 1]).attr("lay-ym", l - 8 + "-" + v[1]).html(e + g + " - " + (l - 1) + g)) : "month" === n ? (lay.each(new Array(12), function(e) {
            var t = lay.elem("li", {
                "lay-ym": e
            }),
                a = {
                    year: v[0],
                    month: e,
                    date: 1
                };
            e + 1 == v[1] && lay(t).addClass(x), t.innerHTML = m.month[e] + (p ? "\u6708" : ""), c.appendChild(t), s.limit({
                elem: lay(t),
                date: a,
                index: i,
                type: n
            })
        }), lay(u[p ? 0 : 1]).attr("lay-ym", v[0] + "-" + v[1]).html(v[0] + g)) : "time" === n && (r = function() {
            lay(c).find("ol").each(function(a, e) {
                lay(e).find("li").each(function(e, t) {
                    s.limit({
                        elem: lay(t),
                        date: [{
                            hours: e
                        }, {
                            hours: s[D].hours,
                            minutes: e
                        }, {
                            hours: s[D].hours,
                            minutes: s[D].minutes,
                            seconds: e
                        }][a],
                        index: i,
                        time: [
                            ["hours"],
                            ["hours", "minutes"],
                            ["hours", "minutes", "seconds"]
                        ][a]
                    })
                })
            }), y.range || s.limit({
                elem: lay(s.footer).find(E),
                date: s[D],
                inedx: 0,
                time: ["hours", "minutes", "seconds"]
            })
        }, y.range ? s[D] || (s[D] = "startTime" === D ? d : s.endDate) : s[D] = d, lay.each([24, 60, 60], function(t, e) {
            var a = lay.elem("li"),
                n = ["<p>" + m.time[t] + "</p><ol>"];
            lay.each(new Array(e), function(e) {
                n.push("<li" + (s[D][T[t]] === e ? ' class="' + x + '"' : "") + ">" + lay.digit(e, 2) + "</li>")
            }), a.innerHTML = n.join("") + "</ol>", c.appendChild(a)
        }), r()), f && h.removeChild(f), h.appendChild(c), "year" === n || "month" === n ? (lay(s.elemMain[i]).addClass("laydate-ym-show"), lay(c).find("li").on("click", function() {
            var e = 0 | lay(this).attr("lay-ym");
            lay(this).hasClass(w) || (0 === i ? (d[n] = e, s.limit({
                elem: lay(s.footer).find(E),
                index: 0
            })) : s.endDate[n] = e, "year" === y.type || "month" === y.type ? (lay(c).find("." + x).removeClass(x), lay(this).addClass(x), "month" === y.type && "year" === n && (s.listYM[i][0] = e, t && ((i ? s.endDate : d).year = e), s.list("month", i))) : (s.checkDate("limit").calendar(null, i), s.closeList()), s.setBtnStatus(), y.range || ("month" === y.type && "month" === n || "year" === y.type && "year" === n) && s.setValue(s.parse()).remove().done(), s.done(null, "change"), lay(s.footer).find("." + k).removeClass(w))
        })) : (e = lay.elem("span", {
            "class": C
        }), o = function() {
            lay(c).find("ol").each(function(e) {
                var a = this,
                    t = lay(a).find("li");
                a.scrollTop = 30 * (s[D][T[e]] - 2), a.scrollTop <= 0 && t.each(function(e, t) {
                    if (!lay(this).hasClass(w)) return a.scrollTop = 30 * (e - 2), !0
                })
            })
        }, u = lay(a[2]).find("." + C), o(), e.innerHTML = y.range ? [m.startTime, m.endTime][i] : m.timeTips, lay(s.elemMain[i]).addClass("laydate-time-show"), u[0] && u.remove(), a[2].appendChild(e), lay(c).find("ol").each(function(t) {
            var a = this;
            lay(a).find("li").on("click", function() {
                var e = 0 | this.innerHTML;
                lay(this).hasClass(w) || (y.range ? s[D][T[t]] = e : d[T[t]] = e, lay(a).find("." + x).removeClass(x), lay(this).addClass(x), r(), o(), !s.endDate && "time" !== y.type || s.done(null, "change"), s.setBtnStatus())
            })
        })), s
    }, T.prototype.listYM = [], T.prototype.closeList = function() {
        var a = this;
        a.config;
        lay.each(a.elemCont, function(e, t) {
            lay(this).find("." + M).remove(), lay(a.elemMain[e]).removeClass("laydate-ym-show laydate-time-show")
        }), lay(a.elem).find("." + C).remove()
    }, T.prototype.setBtnStatus = function(e, t, a) {
        var n = this,
            i = n.config,
            l = n.lang(),
            r = lay(n.footer).find(E);
        i.range && "time" !== i.type && (t = t || i.dateTime, a = a || n.endDate, i = n.newDate(t).getTime() > n.newDate(a).getTime(), n.limit({
            date: t
        }) || n.limit({
            date: a
        }) ? r.addClass(w) : r[i ? "addClass" : "removeClass"](w), e && i && n.hint("string" == typeof e ? l.timeout.replace(/\u65e5\u671f/g, e) : l.timeout))
    }, T.prototype.parse = function(e, t) {
        var a = this,
            n = a.config,
            t = t || ("end" == e ? lay.extend({}, a.endDate, a.endTime) : n.range ? lay.extend({}, n.dateTime, a.startTime) : n.dateTime),
            t = p.parse(t, a.format, 1);
        return n.range && e === undefined ? t + " " + a.rangeStr + " " + a.parse("end") : t
    }, T.prototype.newDate = function(e) {
        return e = e || {}, new Date(e.year || 1, e.month || 0, e.date || 1, e.hours || 0, e.minutes || 0, e.seconds || 0)
    }, T.prototype.getDateTime = function(e) {
        return this.newDate(e).getTime()
    }, T.prototype.setValue = function(e) {
        var t = this,
            a = t.config,
            n = t.bindElem || a.elem[0];
        return "static" === a.position || (e = e || "", t.isInput(n) ? lay(n).val(e) : (a = t.rangeElem) ? ("array" !== layui.type(e) && (e = e.split(" " + t.rangeStr + " ")), a[0].val(e[0] || ""), a[1].val(e[1] || "")) : (0 === lay(n).find("*").length && lay(n).html(e), lay(n).attr("lay-date", e))), t
    }, T.prototype.preview = function() {
        var e, t = this,
            a = t.config;
        a.isPreview && (e = lay(t.elem).find("." + v), a = !a.range || t.endDate ? t.parse() : "", e.html(a).css({
            color: "#5FB878"
        }), setTimeout(function() {
            e.css({
                color: "#666"
            })
        }, 300))
    }, T.prototype.renderAdditional = function() {
        this.config.fullPanel && this.list("time", 0)
    }, T.prototype.done = function(e, t) {
        var a = this,
            n = a.config,
            i = lay.extend({}, lay.extend(n.dateTime, a.startTime)),
            l = lay.extend({}, lay.extend(a.endDate, a.endTime));
        return lay.each([i, l], function(e, t) {
            "month" in t && lay.extend(t, {
                month: t.month + 1
            })
        }), a.preview(), e = e || [a.parse(), i, l], "change" === t && a.renderAdditional(), "function" == typeof n[t || "done"] && n[t || "done"].apply(n, e), a
    }, T.prototype.choose = function(e, a) {
        var n = this,
            i = n.config,
            l = n.thisDateTime(a),
            t = (lay(n.elem).find("td"), {
                year: 0 | (t = e.attr("lay-ymd").split("-"))[0],
                month: (0 | t[1]) - 1,
                date: 0 | t[2]
            });
        e.hasClass(w) || (lay.extend(l, t), i.range ? (lay.each(["startTime", "endTime"], function(e, t) {
            n[t] = n[t] || {
                hours: e ? 23 : 0,
                minutes: e ? 59 : 0,
                seconds: e ? 59 : 0
            }, a === e && (n.getDateTime(lay.extend({}, l, n[t])) < n.getDateTime(i.min) ? (n[t] = {
                hours: i.min.hours,
                minutes: i.min.minutes,
                seconds: i.min.seconds
            }, lay.extend(l, n[t])) : n.getDateTime(lay.extend({}, l, n[t])) > n.getDateTime(i.max) && (n[t] = {
                hours: i.max.hours,
                minutes: i.max.minutes,
                seconds: i.max.seconds
            }, lay.extend(l, n[t])))
        }), n.calendar(null, a).done(null, "change")) : "static" === i.position ? n.calendar().done().done(null, "change") : "date" === i.type ? n.setValue(n.parse()).remove().done() : "datetime" === i.type && n.calendar().done(null, "change"))
    }, T.prototype.tool = function(t, e) {
        var a = this,
            n = a.config,
            i = a.lang(),
            l = n.dateTime,
            r = "static" === n.position,
            o = {
                datetime: function() {
                    lay(t).hasClass(w) || (a.list("time", 0), n.range && a.list("time", 1), lay(t).attr("lay-type", "date").html(a.lang().dateTips))
                },
                date: function() {
                    a.closeList(), lay(t).attr("lay-type", "datetime").html(a.lang().timeTips)
                },
                clear: function() {
                    r && (lay.extend(l, a.firstDate), a.calendar()), n.range && (delete n.dateTime, delete a.endDate, delete a.startTime, delete a.endTime), a.setValue("").remove(), a.done(["",
                    {}, {}])
                },
                now: function() {
                    var e = new Date;
                    if (lay(t).hasClass(w)) return a.hint(i.tools.now + ", " + i.invalidDate);
                    lay.extend(l, a.systemDate(), {
                        hours: e.getHours(),
                        minutes: e.getMinutes(),
                        seconds: e.getSeconds()
                    }), a.setValue(a.parse()).remove(), r && a.calendar(), a.done()
                },
                confirm: function() {
                    if (n.range) {
                        if (lay(t).hasClass(w)) return a.hint("time" === n.type ? i.timeout.replace(/\u65e5\u671f/g, "\u65f6\u95f4") : i.timeout)
                    } else if (lay(t).hasClass(w)) return a.hint(i.invalidDate);
                    a.setValue(a.parse()).remove(), a.done()
                }
            };
        o[e] && o[e]()
    }, T.prototype.change = function(n) {
        var i = this,
            l = i.config,
            r = i.thisDateTime(n),
            o = l.range && ("year" === l.type || "month" === l.type),
            s = i.elemCont[n || 0],
            y = i.listYM[n],
            e = function(e) {
                var t = lay(s).find(".laydate-year-list")[0],
                    a = lay(s).find(".laydate-month-list")[0];
                return t && (y[0] = e ? y[0] - 15 : y[0] + 15, i.list("year", n)), a && (e ? y[0]-- : y[0]++, i.list("month", n)), (t || a) && (lay.extend(r, {
                    year: y[0]
                }), o && (r.year = y[0]), l.range || i.done(null, "change"), l.range || i.limit({
                    elem: lay(i.footer).find(E),
                    date: {
                        year: y[0]
                    }
                })), i.setBtnStatus(), t || a
            };
        return {
            prevYear: function() {
                e("sub") || (r.year--, i.checkDate("limit").calendar(null, n), i.done(null, "change"))
            },
            prevMonth: function() {
                var e = i.getAsYM(r.year, r.month, "sub");
                lay.extend(r, {
                    year: e[0],
                    month: e[1]
                }), i.checkDate("limit").calendar(null, n), i.done(null, "change")
            },
            nextMonth: function() {
                var e = i.getAsYM(r.year, r.month);
                lay.extend(r, {
                    year: e[0],
                    month: e[1]
                }), i.checkDate("limit").calendar(null, n), i.done(null, "change")
            },
            nextYear: function() {
                e() || (r.year++, i.checkDate("limit").calendar(null, n), i.done(null, "change"))
            }
        }
    }, T.prototype.changeEvent = function() {
        var i = this;
        i.config;
        lay(i.elem).on("click", function(e) {
            lay.stope(e)
        }).on("mousedown", function(e) {
            lay.stope(e)
        }), lay.each(i.elemHeader, function(n, e) {
            lay(e[0]).on("click", function(e) {
                i.change(n).prevYear()
            }), lay(e[1]).on("click", function(e) {
                i.change(n).prevMonth()
            }), lay(e[2]).find("span").on("click", function(e) {
                var t = lay(this),
                    a = t.attr("lay-ym"),
                    t = t.attr("lay-type");
                a && (a = a.split("-"), i.listYM[n] = [0 | a[0], 0 | a[1]], i.list(t, n), lay(i.footer).find("." + k).addClass(w))
            }), lay(e[3]).on("click", function(e) {
                i.change(n).nextMonth()
            }), lay(e[4]).on("click", function(e) {
                i.change(n).nextYear()
            })
        }), lay.each(i.table, function(e, t) {
            lay(t).find("td").on("click", function() {
                i.choose(lay(this), e)
            })
        }), lay(i.footer).find("span").on("click", function() {
            var e = lay(this).attr("lay-type");
            i.tool(this, e)
        })
    }, T.prototype.isInput = function(e) {
        return /input|textarea/.test(e.tagName.toLocaleLowerCase()) || /INPUT|TEXTAREA/.test(e.tagName)
    }, T.prototype.events = function() {
        var e, t = this,
            a = t.config;
        a.elem[0] && !a.elem[0].eventHandler && (a.elem.on(a.trigger, e = function() {
            p.thisId !== a.id && (t.bindElem = this, t.render())
        }), a.elem[0].eventHandler = !0, a.eventElem.on(a.trigger, e), t.destroy = function() {
            t.remove(), a.elem.off(a.trigger, e), a.elem.removeAttr("lay-key"), a.elem[0].eventHandler = !1, a.eventElem.off(a.trigger, e), a.eventElem.removeAttr("lay-key"), delete s.that[a.id]
        })
    }, s.that = {}, s.getThis = function(e) {
        var t = s.that[e];
        return !t && n && layui.hint().error(e ? a + " instance with ID '" + e + "' not found" : "ID argument required"), t
    }, l.run = function(n) {
        n(f).on("mousedown", function(e) {
            var t, a;
            !p.thisId || (t = s.getThis(p.thisId)) && (a = t.config, e.target !== a.elem[0] && e.target !== a.eventElem[0] && e.target !== n(a.closeStop)[0] && t.remove())
        }).on("keydown", function(e) {
            var t;
            !p.thisId || (t = s.getThis(p.thisId)) && "static" !== t.config.position && 13 === e.keyCode && n("#" + t.elemID)[0] && t.elemID === T.thisElemDate && (e.preventDefault(), n(t.footer).find(E)[0].click())
        }), n(i).on("resize", function() {
            if (p.thisId) {
                var e = s.getThis(p.thisId);
                if (e) return !(!e.elem || !n(".layui-laydate")[0]) && void e.position()
            }
        })
    }, p.render = function(e) {
        e = new T(e);
        return s.call(e)
    }, p.getInst = function(e) {
        e = s.getThis(e);
        if (e) return e.inst
    }, p.parse = function(a, n, i) {
        return a = a || {}, n = ((n = "string" == typeof n ? s.formatArr(n) : n) || []).concat(), lay.each(n, function(e, t) {
            /yyyy|y/.test(t) ? n[e] = lay.digit(a.year, t.length) : /MM|M/.test(t) ? n[e] = lay.digit(a.month + (i || 0), t.length) : /dd|d/.test(t) ? n[e] = lay.digit(a.date, t.length) : /HH|H/.test(t) ? n[e] = lay.digit(a.hours, t.length) : /mm|m/.test(t) ? n[e] = lay.digit(a.minutes, t.length) : /ss|s/.test(t) && (n[e] = lay.digit(a.seconds, t.length))
        }), n.join("")
    }, p.getEndDate = function(e, t) {
        var a = new Date;
        return a.setFullYear(t || a.getFullYear(), e || a.getMonth() + 1, 1), new Date(a.getTime() - 864e5).getDate()
    }, p.close = function(e) {
        e = s.getThis(e || p.thisId);
        if (e) return e.remove()
    }, p.destroy = function(e) {
        e = s.getThis(e || p.thisId);
        if (e) return e.destroy()
    }, n ? (p.ready(), layui.define("lay", function(e) {
        p.path = layui.cache.dir, l.run(lay), e(a, p)
    })) : "function" == typeof define && define.amd ? define(function() {
        return l.run(lay), p
    }) : (p.ready(), l.run(i.lay), i.laydate = p)
}(window, window.document);
!
function(e, t) {
    "object" == typeof module && "object" == typeof module.exports ? module.exports = e.document ? t(e) : function(e) {
        if (e.document) return t(e);
        throw new Error("jQuery requires a window with a document")
    } : t(e)
}("undefined" != typeof window ? window : this, function(T, M) {
    var f = [],
        g = T.document,
        c = f.slice,
        O = f.concat,
        R = f.push,
        P = f.indexOf,
        B = {},
        W = B.toString,
        m = B.hasOwnProperty,
        y = {},
        e = "1.12.4",
        C = function(e, t) {
            return new C.fn.init(e, t)
        },
        I = /^[\s\uFEFF\xA0]+|[\s\uFEFF\xA0]+$/g,
        $ = /^-ms-/,
        z = /-([\da-z])/gi,
        X = function(e, t) {
            return t.toUpperCase()
        };

    function U(e) {
        var t = !! e && "length" in e && e.length,
            n = C.type(e);
        return "function" !== n && !C.isWindow(e) && ("array" === n || 0 === t || "number" == typeof t && 0 < t && t - 1 in e)
    }
    C.fn = C.prototype = {
        jquery: e,
        constructor: C,
        selector: "",
        length: 0,
        toArray: function() {
            return c.call(this)
        },
        get: function(e) {
            return null != e ? e < 0 ? this[e + this.length] : this[e] : c.call(this)
        },
        pushStack: function(e) {
            e = C.merge(this.constructor(), e);
            return e.prevObject = this, e.context = this.context, e
        },
        each: function(e) {
            return C.each(this, e)
        },
        map: function(n) {
            return this.pushStack(C.map(this, function(e, t) {
                return n.call(e, t, e)
            }))
        },
        slice: function() {
            return this.pushStack(c.apply(this, arguments))
        },
        first: function() {
            return this.eq(0)
        },
        last: function() {
            return this.eq(-1)
        },
        eq: function(e) {
            var t = this.length,
                e = +e + (e < 0 ? t : 0);
            return this.pushStack(0 <= e && e < t ? [this[e]] : [])
        },
        end: function() {
            return this.prevObject || this.constructor()
        },
        push: R,
        sort: f.sort,
        splice: f.splice
    }, C.extend = C.fn.extend = function() {
        var e, t, n, r, i, o = arguments[0] || {},
            a = 1,
            s = arguments.length,
            u = !1;
        for ("boolean" == typeof o && (u = o, o = arguments[a] || {}, a++), "object" == typeof o || C.isFunction(o) || (o = {}), a === s && (o = this, a--); a < s; a++) if (null != (r = arguments[a])) for (n in r) i = o[n], o !== (t = r[n]) && (u && t && (C.isPlainObject(t) || (e = C.isArray(t))) ? (i = e ? (e = !1, i && C.isArray(i) ? i : []) : i && C.isPlainObject(i) ? i : {}, o[n] = C.extend(u, i, t)) : t !== undefined && (o[n] = t));
        return o
    }, C.extend({
        expando: "jQuery" + (e + Math.random()).replace(/\D/g, ""),
        isReady: !0,
        error: function(e) {
            throw new Error(e)
        },
        noop: function() {},
        isFunction: function(e) {
            return "function" === C.type(e)
        },
        isArray: Array.isArray ||
        function(e) {
            return "array" === C.type(e)
        },
        isWindow: function(e) {
            return null != e && e == e.window
        },
        isNumeric: function(e) {
            var t = e && e.toString();
            return !C.isArray(e) && 0 <= t - parseFloat(t) + 1
        },
        isEmptyObject: function(e) {
            for (var t in e) return !1;
            return !0
        },
        isPlainObject: function(e) {
            if (!e || "object" !== C.type(e) || e.nodeType || C.isWindow(e)) return !1;
            try {
                if (e.constructor && !m.call(e, "constructor") && !m.call(e.constructor.prototype, "isPrototypeOf")) return !1
            } catch (n) {
                return !1
            }
            if (!y.ownFirst) for (var t in e) return m.call(e, t);
            for (t in e);
            return t === undefined || m.call(e, t)
        },
        type: function(e) {
            return null == e ? e + "" : "object" == typeof e || "function" == typeof e ? B[W.call(e)] || "object" : typeof e
        },
        globalEval: function(e) {
            e && C.trim(e) && (T.execScript ||
            function(e) {
                T.eval.call(T, e)
            })(e)
        },
        camelCase: function(e) {
            return e.replace($, "ms-").replace(z, X)
        },
        nodeName: function(e, t) {
            return e.nodeName && e.nodeName.toLowerCase() === t.toLowerCase()
        },
        each: function(e, t) {
            var n, r = 0;
            if (U(e)) for (n = e.length; r < n && !1 !== t.call(e[r], r, e[r]); r++);
            else for (r in e) if (!1 === t.call(e[r], r, e[r])) break;
            return e
        },
        trim: function(e) {
            return null == e ? "" : (e + "").replace(I, "")
        },
        makeArray: function(e, t) {
            t = t || [];
            return null != e && (U(Object(e)) ? C.merge(t, "string" == typeof e ? [e] : e) : R.call(t, e)), t
        },
        inArray: function(e, t, n) {
            var r;
            if (t) {
                if (P) return P.call(t, e, n);
                for (r = t.length, n = n ? n < 0 ? Math.max(0, r + n) : n : 0; n < r; n++) if (n in t && t[n] === e) return n
            }
            return -1
        },
        merge: function(e, t) {
            for (var n = +t.length, r = 0, i = e.length; r < n;) e[i++] = t[r++];
            if (n != n) for (; t[r] !== undefined;) e[i++] = t[r++];
            return e.length = i, e
        },
        grep: function(e, t, n) {
            for (var r = [], i = 0, o = e.length, a = !n; i < o; i++)!t(e[i], i) != a && r.push(e[i]);
            return r
        },
        map: function(e, t, n) {
            var r, i, o = 0,
                a = [];
            if (U(e)) for (r = e.length; o < r; o++) null != (i = t(e[o], o, n)) && a.push(i);
            else for (o in e) null != (i = t(e[o], o, n)) && a.push(i);
            return O.apply([], a)
        },
        guid: 1,
        proxy: function(e, t) {
            var n, r;
            return "string" == typeof t && (r = e[t], t = e, e = r), C.isFunction(e) ? (n = c.call(arguments, 2), (r = function() {
                return e.apply(t || this, n.concat(c.call(arguments)))
            }).guid = e.guid = e.guid || C.guid++, r) : undefined
        },
        now: function() {
            return +new Date
        },
        support: y
    }), "function" == typeof Symbol && (C.fn[Symbol.iterator] = f[Symbol.iterator]), C.each("Boolean Number String Function Array Date RegExp Object Error Symbol".split(" "), function(e, t) {
        B["[object " + t + "]"] = t.toLowerCase()
    });
    var e = function(M) {
            var e, g, b, o, O, w, R, P, T, u, l, C, E, t, N, m, r, i, y, k = "sizzle" + +new Date,
                v = M.document,
                S = 0,
                B = 0,
                W = le(),
                I = le(),
                A = le(),
                $ = function(e, t) {
                    return e === t && (l = !0), 0
                },
                z = {}.hasOwnProperty,
                n = [],
                X = n.pop,
                U = n.push,
                D = n.push,
                V = n.slice,
                j = function(e, t) {
                    for (var n = 0, r = e.length; n < r; n++) if (e[n] === t) return n;
                    return -1
                },
                Y = "checked|selected|async|autofocus|autoplay|controls|defer|disabled|hidden|ismap|loop|multiple|open|readonly|required|scoped",
                a = "[\\x20\\t\\r\\n\\f]",
                s = "(?:\\\\.|[\\w-]|[^\\x00-\\xa0])+",
                J = "\\[" + a + "*(" + s + ")(?:" + a + "*([*^$|!~]?=)" + a + "*(?:'((?:\\\\.|[^\\\\'])*)'|\"((?:\\\\.|[^\\\\\"])*)\"|(" + s + "))|)" + a + "*\\]",
                G = ":(" + s + ")(?:\\((('((?:\\\\.|[^\\\\'])*)'|\"((?:\\\\.|[^\\\\\"])*)\")|((?:\\\\.|[^\\\\()[\\]]|" + J + ")*)|.*)\\)|)",
                K = new RegExp(a + "+", "g"),
                L = new RegExp("^" + a + "+|((?:^|[^\\\\])(?:\\\\.)*)" + a + "+$", "g"),
                Q = new RegExp("^" + a + "*," + a + "*"),
                Z = new RegExp("^" + a + "*([>+~]|" + a + ")" + a + "*"),
                ee = new RegExp("=" + a + "*([^\\]'\"]*?)" + a + "*\\]", "g"),
                te = new RegExp(G),
                ne = new RegExp("^" + s + "$"),
                f = {
                    ID: new RegExp("^#(" + s + ")"),
                    CLASS: new RegExp("^\\.(" + s + ")"),
                    TAG: new RegExp("^(" + s + "|[*])"),
                    ATTR: new RegExp("^" + J),
                    PSEUDO: new RegExp("^" + G),
                    CHILD: new RegExp("^:(only|first|last|nth|nth-last)-(child|of-type)(?:\\(" + a + "*(even|odd|(([+-]|)(\\d*)n|)" + a + "*(?:([+-]|)" + a + "*(\\d+)|))" + a + "*\\)|)", "i"),
                    bool: new RegExp("^(?:" + Y + ")$", "i"),
                    needsContext: new RegExp("^" + a + "*[>+~]|:(even|odd|eq|gt|lt|nth|first|last)(?:\\(" + a + "*((?:-\\d)?\\d*)" + a + "*\\)|)(?=[^-]|$)", "i")
                },
                re = /^(?:input|select|textarea|button)$/i,
                ie = /^h\d$/i,
                c = /^[^{]+\{\s*\[native \w/,
                oe = /^(?:#([\w-]+)|(\w+)|\.([\w-]+))$/,
                ae = /[+~]/,
                se = /'|\\/g,
                d = new RegExp("\\\\([\\da-f]{1,6}" + a + "?|(" + a + ")|.)", "ig"),
                p = function(e, t, n) {
                    var r = "0x" + t - 65536;
                    return r != r || n ? t : r < 0 ? String.fromCharCode(65536 + r) : String.fromCharCode(r >> 10 | 55296, 1023 & r | 56320)
                },
                ue = function() {
                    C()
                };
            try {
                D.apply(n = V.call(v.childNodes), v.childNodes), n[v.childNodes.length].nodeType
            } catch (F) {
                D = {
                    apply: n.length ?
                    function(e, t) {
                        U.apply(e, V.call(t))
                    } : function(e, t) {
                        for (var n = e.length, r = 0; e[n++] = t[r++];);
                        e.length = n - 1
                    }
                }
            }
            function H(e, t, n, r) {
                var i, o, a, s, u, l, c, f, d = t && t.ownerDocument,
                    p = t ? t.nodeType : 9;
                if (n = n || [], "string" != typeof e || !e || 1 !== p && 9 !== p && 11 !== p) return n;
                if (!r && ((t ? t.ownerDocument || t : v) !== E && C(t), t = t || E, N)) {
                    if (11 !== p && (l = oe.exec(e))) if (i = l[1]) {
                        if (9 === p) {
                            if (!(a = t.getElementById(i))) return n;
                            if (a.id === i) return n.push(a), n
                        } else if (d && (a = d.getElementById(i)) && y(t, a) && a.id === i) return n.push(a), n
                    } else {
                        if (l[2]) return D.apply(n, t.getElementsByTagName(e)), n;
                        if ((i = l[3]) && g.getElementsByClassName && t.getElementsByClassName) return D.apply(n, t.getElementsByClassName(i)), n
                    }
                    if (g.qsa && !A[e + " "] && (!m || !m.test(e))) {
                        if (1 !== p) d = t, f = e;
                        else if ("object" !== t.nodeName.toLowerCase()) {
                            for ((s = t.getAttribute("id")) ? s = s.replace(se, "\\$&") : t.setAttribute("id", s = k), o = (c = w(e)).length, u = ne.test(s) ? "#" + s : "[id='" + s + "']"; o--;) c[o] = u + " " + _(c[o]);
                            f = c.join(","), d = ae.test(e) && de(t.parentNode) || t
                        }
                        if (f) try {
                            return D.apply(n, d.querySelectorAll(f)), n
                        } catch (h) {} finally {
                            s === k && t.removeAttribute("id")
                        }
                    }
                }
                return P(e.replace(L, "$1"), t, n, r)
            }
            function le() {
                var n = [];

                function r(e, t) {
                    return n.push(e + " ") > b.cacheLength && delete r[n.shift()], r[e + " "] = t
                }
                return r
            }
            function q(e) {
                return e[k] = !0, e
            }
            function h(e) {
                var t = E.createElement("div");
                try {
                    return !!e(t)
                } catch (F) {
                    return !1
                } finally {
                    t.parentNode && t.parentNode.removeChild(t)
                }
            }
            function ce(e, t) {
                for (var n = e.split("|"), r = n.length; r--;) b.attrHandle[n[r]] = t
            }
            function fe(e, t) {
                var n = t && e,
                    r = n && 1 === e.nodeType && 1 === t.nodeType && (~t.sourceIndex || 1 << 31) - (~e.sourceIndex || 1 << 31);
                if (r) return r;
                if (n) for (; n = n.nextSibling;) if (n === t) return -1;
                return e ? 1 : -1
            }
            function x(a) {
                return q(function(o) {
                    return o = +o, q(function(e, t) {
                        for (var n, r = a([], e.length, o), i = r.length; i--;) e[n = r[i]] && (e[n] = !(t[n] = e[n]))
                    })
                })
            }
            function de(e) {
                return e && "undefined" != typeof e.getElementsByTagName && e
            }
            for (e in g = H.support = {}, O = H.isXML = function(e) {
                e = e && (e.ownerDocument || e).documentElement;
                return !!e && "HTML" !== e.nodeName
            }, C = H.setDocument = function(e) {
                var e = e ? e.ownerDocument || e : v;
                return e !== E && 9 === e.nodeType && e.documentElement && (t = (E = e).documentElement, N = !O(E), (e = E.defaultView) && e.top !== e && (e.addEventListener ? e.addEventListener("unload", ue, !1) : e.attachEvent && e.attachEvent("onunload", ue)), g.attributes = h(function(e) {
                    return e.className = "i", !e.getAttribute("className")
                }), g.getElementsByTagName = h(function(e) {
                    return e.appendChild(E.createComment("")), !e.getElementsByTagName("*").length
                }), g.getElementsByClassName = c.test(E.getElementsByClassName), g.getById = h(function(e) {
                    return t.appendChild(e).id = k, !E.getElementsByName || !E.getElementsByName(k).length
                }), g.getById ? (b.find.ID = function(e, t) {
                    if ("undefined" != typeof t.getElementById && N) return (e = t.getElementById(e)) ? [e] : []
                }, b.filter.ID = function(e) {
                    var t = e.replace(d, p);
                    return function(e) {
                        return e.getAttribute("id") === t
                    }
                }) : (delete b.find.ID, b.filter.ID = function(e) {
                    var t = e.replace(d, p);
                    return function(e) {
                        e = "undefined" != typeof e.getAttributeNode && e.getAttributeNode("id");
                        return e && e.value === t
                    }
                }), b.find.TAG = g.getElementsByTagName ?
                function(e, t) {
                    return "undefined" != typeof t.getElementsByTagName ? t.getElementsByTagName(e) : g.qsa ? t.querySelectorAll(e) : void 0
                } : function(e, t) {
                    var n, r = [],
                        i = 0,
                        o = t.getElementsByTagName(e);
                    if ("*" !== e) return o;
                    for (; n = o[i++];) 1 === n.nodeType && r.push(n);
                    return r
                }, b.find.CLASS = g.getElementsByClassName &&
                function(e, t) {
                    if ("undefined" != typeof t.getElementsByClassName && N) return t.getElementsByClassName(e)
                }, r = [], m = [], (g.qsa = c.test(E.querySelectorAll)) && (h(function(e) {
                    t.appendChild(e).innerHTML = "<a id='" + k + "'></a><select id='" + k + "-\r\\' msallowcapture=''><option selected=''></option></select>", e.querySelectorAll("[msallowcapture^='']").length && m.push("[*^$]=" + a + "*(?:''|\"\")"), e.querySelectorAll("[selected]").length || m.push("\\[" + a + "*(?:value|" + Y + ")"), e.querySelectorAll("[id~=" + k + "-]").length || m.push("~="), e.querySelectorAll(":checked").length || m.push(":checked"), e.querySelectorAll("a#" + k + "+*").length || m.push(".#.+[+~]")
                }), h(function(e) {
                    var t = E.createElement("input");
                    t.setAttribute("type", "hidden"), e.appendChild(t).setAttribute("name", "D"), e.querySelectorAll("[name=d]").length && m.push("name" + a + "*[*^$|!~]?="), e.querySelectorAll(":enabled").length || m.push(":enabled", ":disabled"), e.querySelectorAll("*,:x"), m.push(",.*:")
                })), (g.matchesSelector = c.test(i = t.matches || t.webkitMatchesSelector || t.mozMatchesSelector || t.oMatchesSelector || t.msMatchesSelector)) && h(function(e) {
                    g.disconnectedMatch = i.call(e, "div"), i.call(e, "[s!='']:x"), r.push("!=", G)
                }), m = m.length && new RegExp(m.join("|")), r = r.length && new RegExp(r.join("|")), e = c.test(t.compareDocumentPosition), y = e || c.test(t.contains) ?
                function(e, t) {
                    var n = 9 === e.nodeType ? e.documentElement : e,
                        t = t && t.parentNode;
                    return e === t || !(!t || 1 !== t.nodeType || !(n.contains ? n.contains(t) : e.compareDocumentPosition && 16 & e.compareDocumentPosition(t)))
                } : function(e, t) {
                    if (t) for (; t = t.parentNode;) if (t === e) return !0;
                    return !1
                }, $ = e ?
                function(e, t) {
                    if (e === t) return l = !0, 0;
                    var n = !e.compareDocumentPosition - !t.compareDocumentPosition;
                    return n || (1 & (n = (e.ownerDocument || e) === (t.ownerDocument || t) ? e.compareDocumentPosition(t) : 1) || !g.sortDetached && t.compareDocumentPosition(e) === n ? e === E || e.ownerDocument === v && y(v, e) ? -1 : t === E || t.ownerDocument === v && y(v, t) ? 1 : u ? j(u, e) - j(u, t) : 0 : 4 & n ? -1 : 1)
                } : function(e, t) {
                    if (e === t) return l = !0, 0;
                    var n, r = 0,
                        i = e.parentNode,
                        o = t.parentNode,
                        a = [e],
                        s = [t];
                    if (!i || !o) return e === E ? -1 : t === E ? 1 : i ? -1 : o ? 1 : u ? j(u, e) - j(u, t) : 0;
                    if (i === o) return fe(e, t);
                    for (n = e; n = n.parentNode;) a.unshift(n);
                    for (n = t; n = n.parentNode;) s.unshift(n);
                    for (; a[r] === s[r];) r++;
                    return r ? fe(a[r], s[r]) : a[r] === v ? -1 : s[r] === v ? 1 : 0
                }), E
            }, H.matches = function(e, t) {
                return H(e, null, null, t)
            }, H.matchesSelector = function(e, t) {
                if ((e.ownerDocument || e) !== E && C(e), t = t.replace(ee, "='$1']"), g.matchesSelector && N && !A[t + " "] && (!r || !r.test(t)) && (!m || !m.test(t))) try {
                    var n = i.call(e, t);
                    if (n || g.disconnectedMatch || e.document && 11 !== e.document.nodeType) return n
                } catch (F) {}
                return 0 < H(t, E, null, [e]).length
            }, H.contains = function(e, t) {
                return (e.ownerDocument || e) !== E && C(e), y(e, t)
            }, H.attr = function(e, t) {
                (e.ownerDocument || e) !== E && C(e);
                var n = b.attrHandle[t.toLowerCase()],
                    n = n && z.call(b.attrHandle, t.toLowerCase()) ? n(e, t, !N) : undefined;
                return n !== undefined ? n : g.attributes || !N ? e.getAttribute(t) : (n = e.getAttributeNode(t)) && n.specified ? n.value : null
            }, H.error = function(e) {
                throw new Error("Syntax error, unrecognized expression: " + e)
            }, H.uniqueSort = function(e) {
                var t, n = [],
                    r = 0,
                    i = 0;
                if (l = !g.detectDuplicates, u = !g.sortStable && e.slice(0), e.sort($), l) {
                    for (; t = e[i++];) t === e[i] && (r = n.push(i));
                    for (; r--;) e.splice(n[r], 1)
                }
                return u = null, e
            }, o = H.getText = function(e) {
                var t, n = "",
                    r = 0,
                    i = e.nodeType;
                if (i) {
                    if (1 === i || 9 === i || 11 === i) {
                        if ("string" == typeof e.textContent) return e.textContent;
                        for (e = e.firstChild; e; e = e.nextSibling) n += o(e)
                    } else if (3 === i || 4 === i) return e.nodeValue
                } else for (; t = e[r++];) n += o(t);
                return n
            }, (b = H.selectors = {
                cacheLength: 50,
                createPseudo: q,
                match: f,
                attrHandle: {},
                find: {},
                relative: {
                    ">": {
                        dir: "parentNode",
                        first: !0
                    },
                    " ": {
                        dir: "parentNode"
                    },
                    "+": {
                        dir: "previousSibling",
                        first: !0
                    },
                    "~": {
                        dir: "previousSibling"
                    }
                },
                preFilter: {
                    ATTR: function(e) {
                        return e[1] = e[1].replace(d, p), e[3] = (e[3] || e[4] || e[5] || "").replace(d, p), "~=" === e[2] && (e[3] = " " + e[3] + " "), e.slice(0, 4)
                    },
                    CHILD: function(e) {
                        return e[1] = e[1].toLowerCase(), "nth" === e[1].slice(0, 3) ? (e[3] || H.error(e[0]), e[4] = +(e[4] ? e[5] + (e[6] || 1) : 2 * ("even" === e[3] || "odd" === e[3])), e[5] = +(e[7] + e[8] || "odd" === e[3])) : e[3] && H.error(e[0]), e
                    },
                    PSEUDO: function(e) {
                        var t, n = !e[6] && e[2];
                        return f.CHILD.test(e[0]) ? null : (e[3] ? e[2] = e[4] || e[5] || "" : n && te.test(n) && (t = w(n, !0)) && (t = n.indexOf(")", n.length - t) - n.length) && (e[0] = e[0].slice(0, t), e[2] = n.slice(0, t)), e.slice(0, 3))
                    }
                },
                filter: {
                    TAG: function(e) {
                        var t = e.replace(d, p).toLowerCase();
                        return "*" === e ?
                        function() {
                            return !0
                        } : function(e) {
                            return e.nodeName && e.nodeName.toLowerCase() === t
                        }
                    },
                    CLASS: function(e) {
                        var t = W[e + " "];
                        return t || (t = new RegExp("(^|" + a + ")" + e + "(" + a + "|$)")) && W(e, function(e) {
                            return t.test("string" == typeof e.className && e.className || "undefined" != typeof e.getAttribute && e.getAttribute("class") || "")
                        })
                    },
                    ATTR: function(t, n, r) {
                        return function(e) {
                            e = H.attr(e, t);
                            return null == e ? "!=" === n : !n || (e += "", "=" === n ? e === r : "!=" === n ? e !== r : "^=" === n ? r && 0 === e.indexOf(r) : "*=" === n ? r && -1 < e.indexOf(r) : "$=" === n ? r && e.slice(-r.length) === r : "~=" === n ? -1 < (" " + e.replace(K, " ") + " ").indexOf(r) : "|=" === n && (e === r || e.slice(0, r.length + 1) === r + "-"))
                        }
                    },
                    CHILD: function(h, e, t, g, m) {
                        var y = "nth" !== h.slice(0, 3),
                            v = "last" !== h.slice(-4),
                            x = "of-type" === e;
                        return 1 === g && 0 === m ?
                        function(e) {
                            return !!e.parentNode
                        } : function(e, t, n) {
                            var r, i, o, a, s, u, l = y != v ? "nextSibling" : "previousSibling",
                                c = e.parentNode,
                                f = x && e.nodeName.toLowerCase(),
                                d = !n && !x,
                                p = !1;
                            if (c) {
                                if (y) {
                                    for (; l;) {
                                        for (a = e; a = a[l];) if (x ? a.nodeName.toLowerCase() === f : 1 === a.nodeType) return !1;
                                        u = l = "only" === h && !u && "nextSibling"
                                    }
                                    return !0
                                }
                                if (u = [v ? c.firstChild : c.lastChild], v && d) {
                                    for (p = (s = (r = (i = (o = (a = c)[k] || (a[k] = {}))[a.uniqueID] || (o[a.uniqueID] = {}))[h] || [])[0] === S && r[1]) && r[2], a = s && c.childNodes[s]; a = ++s && a && a[l] || (p = s = 0) || u.pop();) if (1 === a.nodeType && ++p && a === e) {
                                        i[h] = [S, s, p];
                                        break
                                    }
                                } else if (!1 === (p = d ? s = (r = (i = (o = (a = e)[k] || (a[k] = {}))[a.uniqueID] || (o[a.uniqueID] = {}))[h] || [])[0] === S && r[1] : p)) for (;
                                (a = ++s && a && a[l] || (p = s = 0) || u.pop()) && ((x ? a.nodeName.toLowerCase() !== f : 1 !== a.nodeType) || !++p || (d && ((i = (o = a[k] || (a[k] = {}))[a.uniqueID] || (o[a.uniqueID] = {}))[h] = [S, p]), a !== e)););
                                return (p -= m) === g || p % g == 0 && 0 <= p / g
                            }
                        }
                    },
                    PSEUDO: function(e, o) {
                        var t, a = b.pseudos[e] || b.setFilters[e.toLowerCase()] || H.error("unsupported pseudo: " + e);
                        return a[k] ? a(o) : 1 < a.length ? (t = [e, e, "", o], b.setFilters.hasOwnProperty(e.toLowerCase()) ? q(function(e, t) {
                            for (var n, r = a(e, o), i = r.length; i--;) e[n = j(e, r[i])] = !(t[n] = r[i])
                        }) : function(e) {
                            return a(e, 0, t)
                        }) : a
                    }
                },
                pseudos: {
                    not: q(function(e) {
                        var r = [],
                            i = [],
                            s = R(e.replace(L, "$1"));
                        return s[k] ? q(function(e, t, n, r) {
                            for (var i, o = s(e, null, r, []), a = e.length; a--;)(i = o[a]) && (e[a] = !(t[a] = i))
                        }) : function(e, t, n) {
                            return r[0] = e, s(r, null, n, i), r[0] = null, !i.pop()
                        }
                    }),
                    has: q(function(t) {
                        return function(e) {
                            return 0 < H(t, e).length
                        }
                    }),
                    contains: q(function(t) {
                        return t = t.replace(d, p), function(e) {
                            return -1 < (e.textContent || e.innerText || o(e)).indexOf(t)
                        }
                    }),
                    lang: q(function(n) {
                        return ne.test(n || "") || H.error("unsupported lang: " + n), n = n.replace(d, p).toLowerCase(), function(e) {
                            var t;
                            do {
                                if (t = N ? e.lang : e.getAttribute("xml:lang") || e.getAttribute("lang")) return (t = t.toLowerCase()) === n || 0 === t.indexOf(n + "-")
                            } while ((e = e.parentNode) && 1 === e.nodeType);
                            return !1
                        }
                    }),
                    target: function(e) {
                        var t = M.location && M.location.hash;
                        return t && t.slice(1) === e.id
                    },
                    root: function(e) {
                        return e === t
                    },
                    focus: function(e) {
                        return e === E.activeElement && (!E.hasFocus || E.hasFocus()) && !! (e.type || e.href || ~e.tabIndex)
                    },
                    enabled: function(e) {
                        return !1 === e.disabled
                    },
                    disabled: function(e) {
                        return !0 === e.disabled
                    },
                    checked: function(e) {
                        var t = e.nodeName.toLowerCase();
                        return "input" === t && !! e.checked || "option" === t && !! e.selected
                    },
                    selected: function(e) {
                        return e.parentNode && e.parentNode.selectedIndex, !0 === e.selected
                    },
                    empty: function(e) {
                        for (e = e.firstChild; e; e = e.nextSibling) if (e.nodeType < 6) return !1;
                        return !0
                    },
                    parent: function(e) {
                        return !b.pseudos.empty(e)
                    },
                    header: function(e) {
                        return ie.test(e.nodeName)
                    },
                    input: function(e) {
                        return re.test(e.nodeName)
                    },
                    button: function(e) {
                        var t = e.nodeName.toLowerCase();
                        return "input" === t && "button" === e.type || "button" === t
                    },
                    text: function(e) {
                        return "input" === e.nodeName.toLowerCase() && "text" === e.type && (null == (e = e.getAttribute("type")) || "text" === e.toLowerCase())
                    },
                    first: x(function() {
                        return [0]
                    }),
                    last: x(function(e, t) {
                        return [t - 1]
                    }),
                    eq: x(function(e, t, n) {
                        return [n < 0 ? n + t : n]
                    }),
                    even: x(function(e, t) {
                        for (var n = 0; n < t; n += 2) e.push(n);
                        return e
                    }),
                    odd: x(function(e, t) {
                        for (var n = 1; n < t; n += 2) e.push(n);
                        return e
                    }),
                    lt: x(function(e, t, n) {
                        for (var r = n < 0 ? n + t : n; 0 <= --r;) e.push(r);
                        return e
                    }),
                    gt: x(function(e, t, n) {
                        for (var r = n < 0 ? n + t : n; ++r < t;) e.push(r);
                        return e
                    })
                }
            }).pseudos.nth = b.pseudos.eq, {
                radio: !0,
                checkbox: !0,
                file: !0,
                password: !0,
                image: !0
            }) b.pseudos[e] = function(t) {
                return function(e) {
                    return "input" === e.nodeName.toLowerCase() && e.type === t
                }
            }(e);
            for (e in {
                submit: !0,
                reset: !0
            }) b.pseudos[e] = function(n) {
                return function(e) {
                    var t = e.nodeName.toLowerCase();
                    return ("input" === t || "button" === t) && e.type === n
                }
            }(e);

            function pe() {}
            function _(e) {
                for (var t = 0, n = e.length, r = ""; t < n; t++) r += e[t].value;
                return r
            }
            function he(a, e, t) {
                var s = e.dir,
                    u = t && "parentNode" === s,
                    l = B++;
                return e.first ?
                function(e, t, n) {
                    for (; e = e[s];) if (1 === e.nodeType || u) return a(e, t, n)
                } : function(e, t, n) {
                    var r, i, o = [S, l];
                    if (n) {
                        for (; e = e[s];) if ((1 === e.nodeType || u) && a(e, t, n)) return !0
                    } else for (; e = e[s];) if (1 === e.nodeType || u) {
                        if ((r = (i = (i = e[k] || (e[k] = {}))[e.uniqueID] || (i[e.uniqueID] = {}))[s]) && r[0] === S && r[1] === l) return o[2] = r[2];
                        if ((i[s] = o)[2] = a(e, t, n)) return !0
                    }
                }
            }
            function ge(i) {
                return 1 < i.length ?
                function(e, t, n) {
                    for (var r = i.length; r--;) if (!i[r](e, t, n)) return !1;
                    return !0
                } : i[0]
            }
            function me(e, t, n, r, i) {
                for (var o, a = [], s = 0, u = e.length, l = null != t; s < u; s++)!(o = e[s]) || n && !n(o, r, i) || (a.push(o), l && t.push(s));
                return a
            }
            function ye(p, h, g, m, y, e) {
                return m && !m[k] && (m = ye(m)), y && !y[k] && (y = ye(y, e)), q(function(e, t, n, r) {
                    var i, o, a, s = [],
                        u = [],
                        l = t.length,
                        c = e ||
                    function(e, t, n) {
                        for (var r = 0, i = t.length; r < i; r++) H(e, t[r], n);
                        return n
                    }(h || "*", n.nodeType ? [n] : n, []), f = !p || !e && h ? c : me(c, s, p, n, r), d = g ? y || (e ? p : l || m) ? [] : t : f;
                    if (g && g(f, d, n, r), m) for (i = me(d, u), m(i, [], n, r), o = i.length; o--;)(a = i[o]) && (d[u[o]] = !(f[u[o]] = a));
                    if (e) {
                        if (y || p) {
                            if (y) {
                                for (i = [], o = d.length; o--;)(a = d[o]) && i.push(f[o] = a);
                                y(null, d = [], i, r)
                            }
                            for (o = d.length; o--;)(a = d[o]) && -1 < (i = y ? j(e, a) : s[o]) && (e[i] = !(t[i] = a))
                        }
                    } else d = me(d === t ? d.splice(l, d.length) : d), y ? y(null, t, d, r) : D.apply(t, d)
                })
            }
            return pe.prototype = b.filters = b.pseudos, b.setFilters = new pe, w = H.tokenize = function(e, t) {
                var n, r, i, o, a, s, u, l = I[e + " "];
                if (l) return t ? 0 : l.slice(0);
                for (a = e, s = [], u = b.preFilter; a;) {
                    for (o in n && !(r = Q.exec(a)) || (r && (a = a.slice(r[0].length) || a), s.push(i = [])), n = !1, (r = Z.exec(a)) && (n = r.shift(), i.push({
                        value: n,
                        type: r[0].replace(L, " ")
                    }), a = a.slice(n.length)), b.filter)!(r = f[o].exec(a)) || u[o] && !(r = u[o](r)) || (n = r.shift(), i.push({
                        value: n,
                        type: o,
                        matches: r
                    }), a = a.slice(n.length));
                    if (!n) break
                }
                return t ? a.length : a ? H.error(e) : I(e, s).slice(0)
            }, R = H.compile = function(e, t) {
                var n, m, y, v, x, r, i = [],
                    o = [],
                    a = A[e + " "];
                if (!a) {
                    for (n = (t = t || w(e)).length; n--;)((a = function f(e) {
                        for (var r, t, n, i = e.length, o = b.relative[e[0].type], a = o || b.relative[" "], s = o ? 1 : 0, u = he(function(e) {
                            return e === r
                        }, a, !0), l = he(function(e) {
                            return -1 < j(r, e)
                        }, a, !0), c = [function(e, t, n) {
                            return e = !o && (n || t !== T) || ((r = t).nodeType ? u : l)(e, t, n), r = null, e
                        }]; s < i; s++) if (t = b.relative[e[s].type]) c = [he(ge(c), t)];
                        else {
                            if ((t = b.filter[e[s].type].apply(null, e[s].matches))[k]) {
                                for (n = ++s; n < i && !b.relative[e[n].type]; n++);
                                return ye(1 < s && ge(c), 1 < s && _(e.slice(0, s - 1).concat({
                                    value: " " === e[s - 2].type ? "*" : ""
                                })).replace(L, "$1"), t, s < n && f(e.slice(s, n)), n < i && f(e = e.slice(n)), n < i && _(e))
                            }
                            c.push(t)
                        }
                        return ge(c)
                    }(t[n]))[k] ? i : o).push(a);
                    (a = A(e, (m = o, v = 0 < (y = i).length, x = 0 < m.length, r = function(e, t, n, r, i) {
                        var o, a, s, u = 0,
                            l = "0",
                            c = e && [],
                            f = [],
                            d = T,
                            p = e || x && b.find.TAG("*", i),
                            h = S += null == d ? 1 : Math.random() || .1,
                            g = p.length;
                        for (i && (T = t === E || t || i); l !== g && null != (o = p[l]); l++) {
                            if (x && o) {
                                for (a = 0, t || o.ownerDocument === E || (C(o), n = !N); s = m[a++];) if (s(o, t || E, n)) {
                                    r.push(o);
                                    break
                                }
                                i && (S = h)
                            }
                            v && ((o = !s && o) && u--, e && c.push(o))
                        }
                        if (u += l, v && l !== u) {
                            for (a = 0; s = y[a++];) s(c, f, t, n);
                            if (e) {
                                if (0 < u) for (; l--;) c[l] || f[l] || (f[l] = X.call(r));
                                f = me(f)
                            }
                            D.apply(r, f), i && !e && 0 < f.length && 1 < u + y.length && H.uniqueSort(r)
                        }
                        return i && (S = h, T = d), c
                    }, v ? q(r) : r))).selector = e
                }
                return a
            }, P = H.select = function(e, t, n, r) {
                var i, o, a, s, u, l = "function" == typeof e && e,
                    c = !r && w(e = l.selector || e);
                if (n = n || [], 1 === c.length) {
                    if (2 < (o = c[0] = c[0].slice(0)).length && "ID" === (a = o[0]).type && g.getById && 9 === t.nodeType && N && b.relative[o[1].type]) {
                        if (!(t = (b.find.ID(a.matches[0].replace(d, p), t) || [])[0])) return n;
                        l && (t = t.parentNode), e = e.slice(o.shift().value.length)
                    }
                    for (i = f.needsContext.test(e) ? 0 : o.length; i-- && (a = o[i], !b.relative[s = a.type]);) if ((u = b.find[s]) && (r = u(a.matches[0].replace(d, p), ae.test(o[0].type) && de(t.parentNode) || t))) {
                        if (o.splice(i, 1), e = r.length && _(o)) break;
                        return D.apply(n, r), n
                    }
                }
                return (l || R(e, c))(r, t, !N, n, !t || ae.test(e) && de(t.parentNode) || t), n
            }, g.sortStable = k.split("").sort($).join("") === k, g.detectDuplicates = !! l, C(), g.sortDetached = h(function(e) {
                return 1 & e.compareDocumentPosition(E.createElement("div"))
            }), h(function(e) {
                return e.innerHTML = "<a href='#'></a>", "#" === e.firstChild.getAttribute("href")
            }) || ce("type|href|height|width", function(e, t, n) {
                if (!n) return e.getAttribute(t, "type" === t.toLowerCase() ? 1 : 2)
            }), g.attributes && h(function(e) {
                return e.innerHTML = "<input/>", e.firstChild.setAttribute("value", ""), "" === e.firstChild.getAttribute("value")
            }) || ce("value", function(e, t, n) {
                if (!n && "input" === e.nodeName.toLowerCase()) return e.defaultValue
            }), h(function(e) {
                return null == e.getAttribute("disabled")
            }) || ce(Y, function(e, t, n) {
                if (!n) return !0 === e[t] ? t.toLowerCase() : (n = e.getAttributeNode(t)) && n.specified ? n.value : null
            }), H
        }(T),
        r = (C.find = e, C.expr = e.selectors, C.expr[":"] = C.expr.pseudos, C.uniqueSort = C.unique = e.uniqueSort, C.text = e.getText, C.isXMLDoc = e.isXML, C.contains = e.contains, function(e, t, n) {
            for (var r = [], i = n !== undefined;
            (e = e[t]) && 9 !== e.nodeType;) if (1 === e.nodeType) {
                if (i && C(e).is(n)) break;
                r.push(e)
            }
            return r
        }),
        V = function(e, t) {
            for (var n = []; e; e = e.nextSibling) 1 === e.nodeType && e !== t && n.push(e);
            return n
        },
        Y = C.expr.match.needsContext,
        J = /^<([\w-]+)\s*\/?>(?:<\/\1>|)$/,
        G = /^.[^:#\[\.,]*$/;

    function K(e, n, r) {
        if (C.isFunction(n)) return C.grep(e, function(e, t) {
            return !!n.call(e, t, e) !== r
        });
        if (n.nodeType) return C.grep(e, function(e) {
            return e === n !== r
        });
        if ("string" == typeof n) {
            if (G.test(n)) return C.filter(n, e, r);
            n = C.filter(n, e)
        }
        return C.grep(e, function(e) {
            return -1 < C.inArray(e, n) !== r
        })
    }
    C.filter = function(e, t, n) {
        var r = t[0];
        return n && (e = ":not(" + e + ")"), 1 === t.length && 1 === r.nodeType ? C.find.matchesSelector(r, e) ? [r] : [] : C.find.matches(e, C.grep(t, function(e) {
            return 1 === e.nodeType
        }))
    }, C.fn.extend({
        find: function(e) {
            var t, n = [],
                r = this,
                i = r.length;
            if ("string" != typeof e) return this.pushStack(C(e).filter(function() {
                for (t = 0; t < i; t++) if (C.contains(r[t], this)) return !0
            }));
            for (t = 0; t < i; t++) C.find(e, r[t], n);
            return (n = this.pushStack(1 < i ? C.unique(n) : n)).selector = this.selector ? this.selector + " " + e : e, n
        },
        filter: function(e) {
            return this.pushStack(K(this, e || [], !1))
        },
        not: function(e) {
            return this.pushStack(K(this, e || [], !0))
        },
        is: function(e) {
            return !!K(this, "string" == typeof e && Y.test(e) ? C(e) : e || [], !1).length
        }
    });
    var Q, Z = /^(?:\s*(<[\w\W]+>)[^>]*|#([\w-]*))$/,
        ee = ((C.fn.init = function(e, t, n) {
            if (!e) return this;
            if (n = n || Q, "string" != typeof e) return e.nodeType ? (this.context = this[0] = e, this.length = 1, this) : C.isFunction(e) ? "undefined" != typeof n.ready ? n.ready(e) : e(C) : (e.selector !== undefined && (this.selector = e.selector, this.context = e.context), C.makeArray(e, this));
            if (!(r = "<" === e.charAt(0) && ">" === e.charAt(e.length - 1) && 3 <= e.length ? [null, e, null] : Z.exec(e)) || !r[1] && t) return (!t || t.jquery ? t || n : this.constructor(t)).find(e);
            if (r[1]) {
                if (t = t instanceof C ? t[0] : t, C.merge(this, C.parseHTML(r[1], t && t.nodeType ? t.ownerDocument || t : g, !0)), J.test(r[1]) && C.isPlainObject(t)) for (var r in t) C.isFunction(this[r]) ? this[r](t[r]) : this.attr(r, t[r]);
                return this
            }
            if ((n = g.getElementById(r[2])) && n.parentNode) {
                if (n.id !== r[2]) return Q.find(e);
                this.length = 1, this[0] = n
            }
            return this.context = g, this.selector = e, this
        }).prototype = C.fn, Q = C(g), /^(?:parents|prev(?:Until|All))/),
        te = {
            children: !0,
            contents: !0,
            next: !0,
            prev: !0
        };

    function ne(e, t) {
        for (;
        (e = e[t]) && 1 !== e.nodeType;);
        return e
    }
    C.fn.extend({
        has: function(e) {
            var t, n = C(e, this),
                r = n.length;
            return this.filter(function() {
                for (t = 0; t < r; t++) if (C.contains(this, n[t])) return !0
            })
        },
        closest: function(e, t) {
            for (var n, r = 0, i = this.length, o = [], a = Y.test(e) || "string" != typeof e ? C(e, t || this.context) : 0; r < i; r++) for (n = this[r]; n && n !== t; n = n.parentNode) if (n.nodeType < 11 && (a ? -1 < a.index(n) : 1 === n.nodeType && C.find.matchesSelector(n, e))) {
                o.push(n);
                break
            }
            return this.pushStack(1 < o.length ? C.uniqueSort(o) : o)
        },
        index: function(e) {
            return e ? "string" == typeof e ? C.inArray(this[0], C(e)) : C.inArray(e.jquery ? e[0] : e, this) : this[0] && this[0].parentNode ? this.first().prevAll().length : -1
        },
        add: function(e, t) {
            return this.pushStack(C.uniqueSort(C.merge(this.get(), C(e, t))))
        },
        addBack: function(e) {
            return this.add(null == e ? this.prevObject : this.prevObject.filter(e))
        }
    }), C.each({
        parent: function(e) {
            e = e.parentNode;
            return e && 11 !== e.nodeType ? e : null
        },
        parents: function(e) {
            return r(e, "parentNode")
        },
        parentsUntil: function(e, t, n) {
            return r(e, "parentNode", n)
        },
        next: function(e) {
            return ne(e, "nextSibling")
        },
        prev: function(e) {
            return ne(e, "previousSibling")
        },
        nextAll: function(e) {
            return r(e, "nextSibling")
        },
        prevAll: function(e) {
            return r(e, "previousSibling")
        },
        nextUntil: function(e, t, n) {
            return r(e, "nextSibling", n)
        },
        prevUntil: function(e, t, n) {
            return r(e, "previousSibling", n)
        },
        siblings: function(e) {
            return V((e.parentNode || {}).firstChild, e)
        },
        children: function(e) {
            return V(e.firstChild)
        },
        contents: function(e) {
            return C.nodeName(e, "iframe") ? e.contentDocument || e.contentWindow.document : C.merge([], e.childNodes)
        }
    }, function(r, i) {
        C.fn[r] = function(e, t) {
            var n = C.map(this, i, e);
            return (t = "Until" !== r.slice(-5) ? e : t) && "string" == typeof t && (n = C.filter(t, n)), 1 < this.length && (te[r] || (n = C.uniqueSort(n)), ee.test(r) && (n = n.reverse())), this.pushStack(n)
        }
    });
    var re, ie, E = /\S+/g;

    function oe() {
        g.addEventListener ? (g.removeEventListener("DOMContentLoaded", i), T.removeEventListener("load", i)) : (g.detachEvent("onreadystatechange", i), T.detachEvent("onload", i))
    }
    function i() {
        !g.addEventListener && "load" !== T.event.type && "complete" !== g.readyState || (oe(), C.ready())
    }
    for (ie in C.Callbacks = function(r) {
        var e, n;
        r = "string" == typeof r ? (e = r, n = {}, C.each(e.match(E) || [], function(e, t) {
            n[t] = !0
        }), n) : C.extend({}, r);
        var i, t, o, a, s = [],
            u = [],
            l = -1,
            c = function() {
                for (a = r.once, o = i = !0; u.length; l = -1) for (t = u.shift(); ++l < s.length;)!1 === s[l].apply(t[0], t[1]) && r.stopOnFalse && (l = s.length, t = !1);
                r.memory || (t = !1), i = !1, a && (s = t ? [] : "")
            },
            f = {
                add: function() {
                    return s && (t && !i && (l = s.length - 1, u.push(t)), function n(e) {
                        C.each(e, function(e, t) {
                            C.isFunction(t) ? r.unique && f.has(t) || s.push(t) : t && t.length && "string" !== C.type(t) && n(t)
                        })
                    }(arguments), t && !i && c()), this
                },
                remove: function() {
                    return C.each(arguments, function(e, t) {
                        for (var n; - 1 < (n = C.inArray(t, s, n));) s.splice(n, 1), n <= l && l--
                    }), this
                },
                has: function(e) {
                    return e ? -1 < C.inArray(e, s) : 0 < s.length
                },
                empty: function() {
                    return s = s && [], this
                },
                disable: function() {
                    return a = u = [], s = t = "", this
                },
                disabled: function() {
                    return !s
                },
                lock: function() {
                    return a = !0, t || f.disable(), this
                },
                locked: function() {
                    return !!a
                },
                fireWith: function(e, t) {
                    return a || (t = [e, (t = t || []).slice ? t.slice() : t], u.push(t), i || c()), this
                },
                fire: function() {
                    return f.fireWith(this, arguments), this
                },
                fired: function() {
                    return !!o
                }
            };
        return f
    }, C.extend({
        Deferred: function(e) {
            var o = [
                ["resolve", "done", C.Callbacks("once memory"), "resolved"],
                ["reject", "fail", C.Callbacks("once memory"), "rejected"],
                ["notify", "progress", C.Callbacks("memory")]
            ],
                i = "pending",
                a = {
                    state: function() {
                        return i
                    },
                    always: function() {
                        return s.done(arguments).fail(arguments), this
                    },
                    then: function() {
                        var i = arguments;
                        return C.Deferred(function(r) {
                            C.each(o, function(e, t) {
                                var n = C.isFunction(i[e]) && i[e];
                                s[t[1]](function() {
                                    var e = n && n.apply(this, arguments);
                                    e && C.isFunction(e.promise) ? e.promise().progress(r.notify).done(r.resolve).fail(r.reject) : r[t[0] + "With"](this === a ? r.promise() : this, n ? [e] : arguments)
                                })
                            }), i = null
                        }).promise()
                    },
                    promise: function(e) {
                        return null != e ? C.extend(e, a) : a
                    }
                },
                s = {};
            return a.pipe = a.then, C.each(o, function(e, t) {
                var n = t[2],
                    r = t[3];
                a[t[1]] = n.add, r && n.add(function() {
                    i = r
                }, o[1 ^ e][2].disable, o[2][2].lock), s[t[0]] = function() {
                    return s[t[0] + "With"](this === s ? a : this, arguments), this
                }, s[t[0] + "With"] = n.fireWith
            }), a.promise(s), e && e.call(s, s), s
        },
        when: function(e) {
            var i, t, n, r = 0,
                o = c.call(arguments),
                a = o.length,
                s = 1 !== a || e && C.isFunction(e.promise) ? a : 0,
                u = 1 === s ? e : C.Deferred(),
                l = function(t, n, r) {
                    return function(e) {
                        n[t] = this, r[t] = 1 < arguments.length ? c.call(arguments) : e, r === i ? u.notifyWith(n, r) : --s || u.resolveWith(n, r)
                    }
                };
            if (1 < a) for (i = new Array(a), t = new Array(a), n = new Array(a); r < a; r++) o[r] && C.isFunction(o[r].promise) ? o[r].promise().progress(l(r, t, i)).done(l(r, n, o)).fail(u.reject) : --s;
            return s || u.resolveWith(n, o), u.promise()
        }
    }), C.fn.ready = function(e) {
        return C.ready.promise().done(e), this
    }, C.extend({
        isReady: !1,
        readyWait: 1,
        holdReady: function(e) {
            e ? C.readyWait++ : C.ready(!0)
        },
        ready: function(e) {
            (!0 === e ? --C.readyWait : C.isReady) || (C.isReady = !0) !== e && 0 < --C.readyWait || (re.resolveWith(g, [C]), C.fn.triggerHandler && (C(g).triggerHandler("ready"), C(g).off("ready")))
        }
    }), C.ready.promise = function(e) {
        if (!re) if (re = C.Deferred(), "complete" === g.readyState || "loading" !== g.readyState && !g.documentElement.doScroll) T.setTimeout(C.ready);
        else if (g.addEventListener) g.addEventListener("DOMContentLoaded", i), T.addEventListener("load", i);
        else {
            g.attachEvent("onreadystatechange", i), T.attachEvent("onload", i);
            var t = !1;
            try {
                t = null == T.frameElement && g.documentElement
            } catch (n) {}
            t && t.doScroll && !
            function r() {
                if (!C.isReady) {
                    try {
                        t.doScroll("left")
                    } catch (n) {
                        return T.setTimeout(r, 50)
                    }
                    oe(), C.ready()
                }
            }()
        }
        return re.promise(e)
    }, C.ready.promise(), C(y)) break;
    y.ownFirst = "0" === ie, y.inlineBlockNeedsLayout = !1, C(function() {
        var e, t, n = g.getElementsByTagName("body")[0];
        n && n.style && (e = g.createElement("div"), (t = g.createElement("div")).style.cssText = "position:absolute;border:0;width:0;height:0;top:0;left:-9999px", n.appendChild(t).appendChild(e), "undefined" != typeof e.style.zoom && (e.style.cssText = "display:inline;margin:0;border:0;padding:1px;width:1px;zoom:1", y.inlineBlockNeedsLayout = e = 3 === e.offsetWidth, e && (n.style.zoom = 1)), n.removeChild(t))
    });
    e = g.createElement("div");
    y.deleteExpando = !0;
    try {
        delete e.test
    } catch (yn) {
        y.deleteExpando = !1
    }
    var o, v = function(e) {
            var t = C.noData[(e.nodeName + " ").toLowerCase()],
                n = +e.nodeType || 1;
            return (1 === n || 9 === n) && (!t || !0 !== t && e.getAttribute("classid") === t)
        },
        ae = /^(?:\{[\w\W]*\}|\[[\w\W]*\])$/,
        se = /([A-Z])/g;

    function ue(e, t, n) {
        if (n === undefined && 1 === e.nodeType) {
            var r = "data-" + t.replace(se, "-$1").toLowerCase();
            if ("string" == typeof(n = e.getAttribute(r))) {
                try {
                    n = "true" === n || "false" !== n && ("null" === n ? null : +n + "" === n ? +n : ae.test(n) ? C.parseJSON(n) : n)
                } catch (i) {}
                C.data(e, t, n)
            } else n = undefined
        }
        return n
    }
    function le(e) {
        for (var t in e) if (("data" !== t || !C.isEmptyObject(e[t])) && "toJSON" !== t) return;
        return 1
    }
    function ce(e, t, n, r) {
        if (v(e)) {
            var i, o = C.expando,
                a = e.nodeType,
                s = a ? C.cache : e,
                u = a ? e[o] : e[o] && o;
            if (u && s[u] && (r || s[u].data) || n !== undefined || "string" != typeof t) return s[u = u || (a ? e[o] = f.pop() || C.guid++ : o)] || (s[u] = a ? {} : {
                toJSON: C.noop
            }), "object" != typeof t && "function" != typeof t || (r ? s[u] = C.extend(s[u], t) : s[u].data = C.extend(s[u].data, t)), e = s[u], r || (e.data || (e.data = {}), e = e.data), n !== undefined && (e[C.camelCase(t)] = n), "string" == typeof t ? null == (i = e[t]) && (i = e[C.camelCase(t)]) : i = e, i
        }
    }
    function fe(e, t, n) {
        if (v(e)) {
            var r, i, o = e.nodeType,
                a = o ? C.cache : e,
                s = o ? e[C.expando] : C.expando;
            if (a[s]) {
                if (t && (r = n ? a[s] : a[s].data)) {
                    i = (t = C.isArray(t) ? t.concat(C.map(t, C.camelCase)) : t in r || (t = C.camelCase(t)) in r ? [t] : t.split(" ")).length;
                    for (; i--;) delete r[t[i]];
                    if (n ? !le(r) : !C.isEmptyObject(r)) return
                }(n || (delete a[s].data, le(a[s]))) && (o ? C.cleanData([e], !0) : y.deleteExpando || a != a.window ? delete a[s] : a[s] = undefined)
            }
        }
    }
    C.extend({
        cache: {},
        noData: {
            "applet ": !0,
            "embed ": !0,
            "object ": "clsid:D27CDB6E-AE6D-11cf-96B8-444553540000"
        },
        hasData: function(e) {
            return !!(e = e.nodeType ? C.cache[e[C.expando]] : e[C.expando]) && !le(e)
        },
        data: function(e, t, n) {
            return ce(e, t, n)
        },
        removeData: function(e, t) {
            return fe(e, t)
        },
        _data: function(e, t, n) {
            return ce(e, t, n, !0)
        },
        _removeData: function(e, t) {
            return fe(e, t, !0)
        }
    }), C.fn.extend({
        data: function(e, t) {
            var n, r, i, o = this[0],
                a = o && o.attributes;
            if (e !== undefined) return "object" == typeof e ? this.each(function() {
                C.data(this, e)
            }) : 1 < arguments.length ? this.each(function() {
                C.data(this, e, t)
            }) : o ? ue(o, e, C.data(o, e)) : undefined;
            if (this.length && (i = C.data(o), 1 === o.nodeType && !C._data(o, "parsedAttrs"))) {
                for (n = a.length; n--;) a[n] && 0 === (r = a[n].name).indexOf("data-") && ue(o, r = C.camelCase(r.slice(5)), i[r]);
                C._data(o, "parsedAttrs", !0)
            }
            return i
        },
        removeData: function(e) {
            return this.each(function() {
                C.removeData(this, e)
            })
        }
    }), C.extend({
        queue: function(e, t, n) {
            var r;
            if (e) return r = C._data(e, t = (t || "fx") + "queue"), n && (!r || C.isArray(n) ? r = C._data(e, t, C.makeArray(n)) : r.push(n)), r || []
        },
        dequeue: function(e, t) {
            t = t || "fx";
            var n = C.queue(e, t),
                r = n.length,
                i = n.shift(),
                o = C._queueHooks(e, t);
            "inprogress" === i && (i = n.shift(), r--), i && ("fx" === t && n.unshift("inprogress"), delete o.stop, i.call(e, function() {
                C.dequeue(e, t)
            }, o)), !r && o && o.empty.fire()
        },
        _queueHooks: function(e, t) {
            var n = t + "queueHooks";
            return C._data(e, n) || C._data(e, n, {
                empty: C.Callbacks("once memory").add(function() {
                    C._removeData(e, t + "queue"), C._removeData(e, n)
                })
            })
        }
    }), C.fn.extend({
        queue: function(t, n) {
            var e = 2;
            return "string" != typeof t && (n = t, t = "fx", e--), arguments.length < e ? C.queue(this[0], t) : n === undefined ? this : this.each(function() {
                var e = C.queue(this, t, n);
                C._queueHooks(this, t), "fx" === t && "inprogress" !== e[0] && C.dequeue(this, t)
            })
        },
        dequeue: function(e) {
            return this.each(function() {
                C.dequeue(this, e)
            })
        },
        clearQueue: function(e) {
            return this.queue(e || "fx", [])
        },
        promise: function(e, t) {
            var n, r = 1,
                i = C.Deferred(),
                o = this,
                a = this.length,
                s = function() {
                    --r || i.resolveWith(o, [o])
                };
            for ("string" != typeof e && (t = e, e = undefined), e = e || "fx"; a--;)(n = C._data(o[a], e + "queueHooks")) && n.empty && (r++, n.empty.add(s));
            return s(), i.promise(t)
        }
    }), y.shrinkWrapBlocks = function() {
        return null != o ? o : (o = !1, (t = g.getElementsByTagName("body")[0]) && t.style ? (e = g.createElement("div"), (n = g.createElement("div")).style.cssText = "position:absolute;border:0;width:0;height:0;top:0;left:-9999px", t.appendChild(n).appendChild(e), "undefined" != typeof e.style.zoom && (e.style.cssText = "-webkit-box-sizing:content-box;-moz-box-sizing:content-box;box-sizing:content-box;display:block;margin:0;border:0;padding:1px;width:1px;zoom:1", e.appendChild(g.createElement("div")).style.width = "5px", o = 3 !== e.offsetWidth), t.removeChild(n), o) : void 0);
        var e, t, n
    };
    var e = /[+-]?(?:\d*\.|)\d+(?:[eE][+-]?\d+|)/.source,
        de = new RegExp("^(?:([+-])=|)(" + e + ")([a-z%]*)$", "i"),
        s = ["Top", "Right", "Bottom", "Left"],
        pe = function(e, t) {
            return "none" === C.css(e = t || e, "display") || !C.contains(e.ownerDocument, e)
        };

    function he(e, t, n, r) {
        var i, o = 1,
            a = 20,
            s = r ?
        function() {
            return r.cur()
        } : function() {
            return C.css(e, t, "")
        }, u = s(), l = n && n[3] || (C.cssNumber[t] ? "" : "px"), c = (C.cssNumber[t] || "px" !== l && +u) && de.exec(C.css(e, t));
        if (c && c[3] !== l) for (l = l || c[3], n = n || [], c = +u || 1; c /= o = o || ".5", C.style(e, t, c + l), o !== (o = s() / u) && 1 !== o && --a;);
        return n && (c = +c || +u || 0, i = n[1] ? c + (n[1] + 1) * n[2] : +n[2], r && (r.unit = l, r.start = c, r.end = i)), i
    }
    var d = function(e, t, n, r, i, o, a) {
            var s = 0,
                u = e.length,
                l = null == n;
            if ("object" === C.type(n)) for (s in i = !0, n) d(e, t, s, n[s], !0, o, a);
            else if (r !== undefined && (i = !0, C.isFunction(r) || (a = !0), t = l ? a ? (t.call(e, r), null) : (l = t, function(e, t, n) {
                return l.call(C(e), n)
            }) : t)) for (; s < u; s++) t(e[s], n, a ? r : r.call(e[s], s, t(e[s], n)));
            return i ? e : l ? t.call(e) : u ? t(e[0], n) : o
        },
        ge = /^(?:checkbox|radio)$/i,
        me = /<([\w:-]+)/,
        ye = /^$|\/(?:java|ecma)script/i,
        ve = /^\s+/,
        xe = "abbr|article|aside|audio|bdi|canvas|data|datalist|details|dialog|figcaption|figure|footer|header|hgroup|main|mark|meter|nav|output|picture|progress|section|summary|template|time|video";

    function be(e) {
        var t = xe.split("|"),
            n = e.createDocumentFragment();
        if (n.createElement) for (; t.length;) n.createElement(t.pop());
        return n
    }
    S = g.createElement("div"), k = g.createDocumentFragment(), q = g.createElement("input"), S.innerHTML = "  <link/><table></table><a href='/a'>a</a><input type='checkbox'/>", y.leadingWhitespace = 3 === S.firstChild.nodeType, y.tbody = !S.getElementsByTagName("tbody").length, y.htmlSerialize = !! S.getElementsByTagName("link").length, y.html5Clone = "<:nav></:nav>" !== g.createElement("nav").cloneNode(!0).outerHTML, q.type = "checkbox", q.checked = !0, k.appendChild(q), y.appendChecked = q.checked, S.innerHTML = "<textarea>x</textarea>", y.noCloneChecked = !! S.cloneNode(!0).lastChild.defaultValue, k.appendChild(S), (q = g.createElement("input")).setAttribute("type", "radio"), q.setAttribute("checked", "checked"), q.setAttribute("name", "t"), S.appendChild(q), y.checkClone = S.cloneNode(!0).cloneNode(!0).lastChild.checked, y.noCloneEvent = !! S.addEventListener, S[C.expando] = 1, y.attributes = !S.getAttribute(C.expando);
    var x = {
        option: [1, "<select multiple='multiple'>", "</select>"],
        legend: [1, "<fieldset>", "</fieldset>"],
        area: [1, "<map>", "</map>"],
        param: [1, "<object>", "</object>"],
        thead: [1, "<table>", "</table>"],
        tr: [2, "<table><tbody>", "</tbody></table>"],
        col: [2, "<table><tbody></tbody><colgroup>", "</colgroup></table>"],
        td: [3, "<table><tbody><tr>", "</tr></tbody></table>"],
        _default: y.htmlSerialize ? [0, "", ""] : [1, "X<div>", "</div>"]
    };

    function b(e, t) {
        var n, r, i = 0,
            o = "undefined" != typeof e.getElementsByTagName ? e.getElementsByTagName(t || "*") : "undefined" != typeof e.querySelectorAll ? e.querySelectorAll(t || "*") : undefined;
        if (!o) for (o = [], n = e.childNodes || e; null != (r = n[i]); i++)!t || C.nodeName(r, t) ? o.push(r) : C.merge(o, b(r, t));
        return t === undefined || t && C.nodeName(e, t) ? C.merge([e], o) : o
    }
    function we(e, t) {
        for (var n, r = 0; null != (n = e[r]); r++) C._data(n, "globalEval", !t || C._data(t[r], "globalEval"))
    }
    x.optgroup = x.option, x.tbody = x.tfoot = x.colgroup = x.caption = x.thead, x.th = x.td;
    var Te = /<|&#?\w+;/,
        Ce = /<tbody/i;

    function Ee(e) {
        ge.test(e.type) && (e.defaultChecked = e.checked)
    }
    function Ne(e, t, n, r, i) {
        for (var o, a, s, u, l, c, f, d = e.length, p = be(t), h = [], g = 0; g < d; g++) if ((a = e[g]) || 0 === a) if ("object" === C.type(a)) C.merge(h, a.nodeType ? [a] : a);
        else if (Te.test(a)) {
            for (u = u || p.appendChild(t.createElement("div")), l = (me.exec(a) || ["", ""])[1].toLowerCase(), f = x[l] || x._default, u.innerHTML = f[1] + C.htmlPrefilter(a) + f[2], o = f[0]; o--;) u = u.lastChild;
            if (!y.leadingWhitespace && ve.test(a) && h.push(t.createTextNode(ve.exec(a)[0])), !y.tbody) for (o = (a = "table" !== l || Ce.test(a) ? "<table>" !== f[1] || Ce.test(a) ? 0 : u : u.firstChild) && a.childNodes.length; o--;) C.nodeName(c = a.childNodes[o], "tbody") && !c.childNodes.length && a.removeChild(c);
            for (C.merge(h, u.childNodes), u.textContent = ""; u.firstChild;) u.removeChild(u.firstChild);
            u = p.lastChild
        } else h.push(t.createTextNode(a));
        for (u && p.removeChild(u), y.appendChecked || C.grep(b(h, "input"), Ee), g = 0; a = h[g++];) if (r && -1 < C.inArray(a, r)) i && i.push(a);
        else if (s = C.contains(a.ownerDocument, a), u = b(p.appendChild(a), "script"), s && we(u), n) for (o = 0; a = u[o++];) ye.test(a.type || "") && n.push(a);
        return u = null, p
    }
    var ke, Se, Ae = g.createElement("div");
    for (ke in {
        submit: !0,
        change: !0,
        focusin: !0
    })(y[ke] = (Se = "on" + ke) in T) || (Ae.setAttribute(Se, "t"), y[ke] = !1 === Ae.attributes[Se].expando);
    var De = /^(?:input|select|textarea)$/i,
        je = /^key/,
        Le = /^(?:mouse|pointer|contextMenu|drag|drop)|click/,
        He = /^(?:focusinfocus|focusoutblur)$/,
        qe = /^([^.]*)(?:\.(.+)|)/;

    function _e() {
        return !0
    }
    function u() {
        return !1
    }
    function Fe() {
        try {
            return g.activeElement
        } catch (e) {}
    }
    function Me(e, t, n, r, i, o) {
        var a, s;
        if ("object" == typeof t) {
            for (s in "string" != typeof n && (r = r || n, n = undefined), t) Me(e, s, n, r, t[s], o);
            return e
        }
        if (null == r && null == i ? (i = n, r = n = undefined) : null == i && ("string" == typeof n ? (i = r, r = undefined) : (i = r, r = n, n = undefined)), !1 === i) i = u;
        else if (!i) return e;
        return 1 === o && (a = i, (i = function(e) {
            return C().off(e), a.apply(this, arguments)
        }).guid = a.guid || (a.guid = C.guid++)), e.each(function() {
            C.event.add(this, t, i, r, n)
        })
    }
    C.event = {
        global: {},
        add: function(e, t, n, r, i) {
            var o, a, s, u, l, c, f, d, p, h = C._data(e);
            if (h) for (n.handler && (n = (s = n).handler, i = s.selector), n.guid || (n.guid = C.guid++), (o = h.events) || (o = h.events = {}), (l = h.handle) || ((l = h.handle = function(e) {
                return void 0 === C || e && C.event.triggered === e.type ? undefined : C.event.dispatch.apply(l.elem, arguments)
            }).elem = e), a = (t = (t || "").match(E) || [""]).length; a--;) f = p = (d = qe.exec(t[a]) || [])[1], d = (d[2] || "").split(".").sort(), f && (u = C.event.special[f] || {}, f = (i ? u.delegateType : u.bindType) || f, u = C.event.special[f] || {}, p = C.extend({
                type: f,
                origType: p,
                data: r,
                handler: n,
                guid: n.guid,
                selector: i,
                needsContext: i && C.expr.match.needsContext.test(i),
                namespace: d.join(".")
            }, s), (c = o[f]) || ((c = o[f] = []).delegateCount = 0, u.setup && !1 !== u.setup.call(e, r, d, l) || (e.addEventListener ? e.addEventListener(f, l, !1) : e.attachEvent && e.attachEvent("on" + f, l))), u.add && (u.add.call(e, p), p.handler.guid || (p.handler.guid = n.guid)), i ? c.splice(c.delegateCount++, 0, p) : c.push(p), C.event.global[f] = !0)
        },
        remove: function(e, t, n, r, i) {
            var o, a, s, u, l, c, f, d, p, h, g, m = C.hasData(e) && C._data(e);
            if (m && (c = m.events)) {
                for (l = (t = (t || "").match(E) || [""]).length; l--;) if (p = g = (s = qe.exec(t[l]) || [])[1], h = (s[2] || "").split(".").sort(), p) {
                    for (f = C.event.special[p] || {}, d = c[p = (r ? f.delegateType : f.bindType) || p] || [], s = s[2] && new RegExp("(^|\\.)" + h.join("\\.(?:.*\\.|)") + "(\\.|$)"), u = o = d.length; o--;) a = d[o], !i && g !== a.origType || n && n.guid !== a.guid || s && !s.test(a.namespace) || r && r !== a.selector && ("**" !== r || !a.selector) || (d.splice(o, 1), a.selector && d.delegateCount--, f.remove && f.remove.call(e, a));
                    u && !d.length && (f.teardown && !1 !== f.teardown.call(e, h, m.handle) || C.removeEvent(e, p, m.handle), delete c[p])
                } else for (p in c) C.event.remove(e, p + t[l], n, r, !0);
                C.isEmptyObject(c) && (delete m.handle, C._removeData(e, "events"))
            }
        },
        trigger: function(e, t, n, r) {
            var i, o, a, s, u, l, c = [n || g],
                f = m.call(e, "type") ? e.type : e,
                d = m.call(e, "namespace") ? e.namespace.split(".") : [],
                p = u = n = n || g;
            if (3 !== n.nodeType && 8 !== n.nodeType && !He.test(f + C.event.triggered) && (-1 < f.indexOf(".") && (f = (d = f.split(".")).shift(), d.sort()), o = f.indexOf(":") < 0 && "on" + f, (e = e[C.expando] ? e : new C.Event(f, "object" == typeof e && e)).isTrigger = r ? 2 : 3, e.namespace = d.join("."), e.rnamespace = e.namespace ? new RegExp("(^|\\.)" + d.join("\\.(?:.*\\.|)") + "(\\.|$)") : null, e.result = undefined, e.target || (e.target = n), t = null == t ? [e] : C.makeArray(t, [e]), s = C.event.special[f] || {}, r || !s.trigger || !1 !== s.trigger.apply(n, t))) {
                if (!r && !s.noBubble && !C.isWindow(n)) {
                    for (a = s.delegateType || f, He.test(a + f) || (p = p.parentNode); p; p = p.parentNode) c.push(p), u = p;
                    u === (n.ownerDocument || g) && c.push(u.defaultView || u.parentWindow || T)
                }
                for (l = 0;
                (p = c[l++]) && !e.isPropagationStopped();) e.type = 1 < l ? a : s.bindType || f, (i = (C._data(p, "events") || {})[e.type] && C._data(p, "handle")) && i.apply(p, t), (i = o && p[o]) && i.apply && v(p) && (e.result = i.apply(p, t), !1 === e.result && e.preventDefault());
                if (e.type = f, !r && !e.isDefaultPrevented() && (!s._default || !1 === s._default.apply(c.pop(), t)) && v(n) && o && n[f] && !C.isWindow(n)) {
                    (u = n[o]) && (n[o] = null), C.event.triggered = f;
                    try {
                        n[f]()
                    } catch (h) {}
                    C.event.triggered = undefined, u && (n[o] = u)
                }
                return e.result
            }
        },
        dispatch: function(e) {
            e = C.event.fix(e);
            var t, n, r, i, o, a = c.call(arguments),
                s = (C._data(this, "events") || {})[e.type] || [],
                u = C.event.special[e.type] || {};
            if ((a[0] = e).delegateTarget = this, !u.preDispatch || !1 !== u.preDispatch.call(this, e)) {
                for (o = C.event.handlers.call(this, e, s), t = 0;
                (r = o[t++]) && !e.isPropagationStopped();) for (e.currentTarget = r.elem, n = 0;
                (i = r.handlers[n++]) && !e.isImmediatePropagationStopped();) e.rnamespace && !e.rnamespace.test(i.namespace) || (e.handleObj = i, e.data = i.data, (i = ((C.event.special[i.origType] || {}).handle || i.handler).apply(r.elem, a)) !== undefined && !1 === (e.result = i) && (e.preventDefault(), e.stopPropagation()));
                return u.postDispatch && u.postDispatch.call(this, e), e.result
            }
        },
        handlers: function(e, t) {
            var n, r, i, o, a = [],
                s = t.delegateCount,
                u = e.target;
            if (s && u.nodeType && ("click" !== e.type || isNaN(e.button) || e.button < 1)) for (; u != this; u = u.parentNode || this) if (1 === u.nodeType && (!0 !== u.disabled || "click" !== e.type)) {
                for (r = [], n = 0; n < s; n++) r[i = (o = t[n]).selector + " "] === undefined && (r[i] = o.needsContext ? -1 < C(i, this).index(u) : C.find(i, this, null, [u]).length), r[i] && r.push(o);
                r.length && a.push({
                    elem: u,
                    handlers: r
                })
            }
            return s < t.length && a.push({
                elem: this,
                handlers: t.slice(s)
            }), a
        },
        fix: function(e) {
            if (e[C.expando]) return e;
            var t, n, r, i = e.type,
                o = e,
                a = this.fixHooks[i];
            for (a || (this.fixHooks[i] = a = Le.test(i) ? this.mouseHooks : je.test(i) ? this.keyHooks : {}), r = a.props ? this.props.concat(a.props) : this.props, e = new C.Event(o), t = r.length; t--;) e[n = r[t]] = o[n];
            return e.target || (e.target = o.srcElement || g), 3 === e.target.nodeType && (e.target = e.target.parentNode), e.metaKey = !! e.metaKey, a.filter ? a.filter(e, o) : e
        },
        props: "altKey bubbles cancelable ctrlKey currentTarget detail eventPhase metaKey relatedTarget shiftKey target timeStamp view which".split(" "),
        fixHooks: {},
        keyHooks: {
            props: "char charCode key keyCode".split(" "),
            filter: function(e, t) {
                return null == e.which && (e.which = null != t.charCode ? t.charCode : t.keyCode), e
            }
        },
        mouseHooks: {
            props: "button buttons clientX clientY fromElement offsetX offsetY pageX pageY screenX screenY toElement".split(" "),
            filter: function(e, t) {
                var n, r, i = t.button,
                    o = t.fromElement;
                return null == e.pageX && null != t.clientX && (r = (n = e.target.ownerDocument || g).documentElement, n = n.body, e.pageX = t.clientX + (r && r.scrollLeft || n && n.scrollLeft || 0) - (r && r.clientLeft || n && n.clientLeft || 0), e.pageY = t.clientY + (r && r.scrollTop || n && n.scrollTop || 0) - (r && r.clientTop || n && n.clientTop || 0)), !e.relatedTarget && o && (e.relatedTarget = o === e.target ? t.toElement : o), e.which || i === undefined || (e.which = 1 & i ? 1 : 2 & i ? 3 : 4 & i ? 2 : 0), e
            }
        },
        special: {
            load: {
                noBubble: !0
            },
            focus: {
                trigger: function() {
                    if (this !== Fe() && this.focus) try {
                        return this.focus(), !1
                    } catch (e) {}
                },
                delegateType: "focusin"
            },
            blur: {
                trigger: function() {
                    if (this === Fe() && this.blur) return this.blur(), !1
                },
                delegateType: "focusout"
            },
            click: {
                trigger: function() {
                    if (C.nodeName(this, "input") && "checkbox" === this.type && this.click) return this.click(), !1
                },
                _default: function(e) {
                    return C.nodeName(e.target, "a")
                }
            },
            beforeunload: {
                postDispatch: function(e) {
                    e.result !== undefined && e.originalEvent && (e.originalEvent.returnValue = e.result)
                }
            }
        },
        simulate: function(e, t, n) {
            e = C.extend(new C.Event, n, {
                type: e,
                isSimulated: !0
            });
            C.event.trigger(e, null, t), e.isDefaultPrevented() && n.preventDefault()
        }
    }, C.removeEvent = g.removeEventListener ?
    function(e, t, n) {
        e.removeEventListener && e.removeEventListener(t, n)
    } : function(e, t, n) {
        t = "on" + t;
        e.detachEvent && ("undefined" == typeof e[t] && (e[t] = null), e.detachEvent(t, n))
    }, C.Event = function(e, t) {
        if (!(this instanceof C.Event)) return new C.Event(e, t);
        e && e.type ? (this.originalEvent = e, this.type = e.type, this.isDefaultPrevented = e.defaultPrevented || e.defaultPrevented === undefined && !1 === e.returnValue ? _e : u) : this.type = e, t && C.extend(this, t), this.timeStamp = e && e.timeStamp || C.now(), this[C.expando] = !0
    }, C.Event.prototype = {
        constructor: C.Event,
        isDefaultPrevented: u,
        isPropagationStopped: u,
        isImmediatePropagationStopped: u,
        preventDefault: function() {
            var e = this.originalEvent;
            this.isDefaultPrevented = _e, e && (e.preventDefault ? e.preventDefault() : e.returnValue = !1)
        },
        stopPropagation: function() {
            var e = this.originalEvent;
            this.isPropagationStopped = _e, e && !this.isSimulated && (e.stopPropagation && e.stopPropagation(), e.cancelBubble = !0)
        },
        stopImmediatePropagation: function() {
            var e = this.originalEvent;
            this.isImmediatePropagationStopped = _e, e && e.stopImmediatePropagation && e.stopImmediatePropagation(), this.stopPropagation()
        }
    }, C.each({
        mouseenter: "mouseover",
        mouseleave: "mouseout",
        pointerenter: "pointerover",
        pointerleave: "pointerout"
    }, function(e, i) {
        C.event.special[e] = {
            delegateType: i,
            bindType: i,
            handle: function(e) {
                var t, n = e.relatedTarget,
                    r = e.handleObj;
                return n && (n === this || C.contains(this, n)) || (e.type = r.origType, t = r.handler.apply(this, arguments), e.type = i), t
            }
        }
    }), y.submit || (C.event.special.submit = {
        setup: function() {
            if (C.nodeName(this, "form")) return !1;
            C.event.add(this, "click._submit keypress._submit", function(e) {
                e = e.target, e = C.nodeName(e, "input") || C.nodeName(e, "button") ? C.prop(e, "form") : undefined;
                e && !C._data(e, "submit") && (C.event.add(e, "submit._submit", function(e) {
                    e._submitBubble = !0
                }), C._data(e, "submit", !0))
            })
        },
        postDispatch: function(e) {
            e._submitBubble && (delete e._submitBubble, this.parentNode && !e.isTrigger && C.event.simulate("submit", this.parentNode, e))
        },
        teardown: function() {
            if (C.nodeName(this, "form")) return !1;
            C.event.remove(this, "._submit")
        }
    }), y.change || (C.event.special.change = {
        setup: function() {
            if (De.test(this.nodeName)) return "checkbox" !== this.type && "radio" !== this.type || (C.event.add(this, "propertychange._change", function(e) {
                "checked" === e.originalEvent.propertyName && (this._justChanged = !0)
            }), C.event.add(this, "click._change", function(e) {
                this._justChanged && !e.isTrigger && (this._justChanged = !1), C.event.simulate("change", this, e)
            })), !1;
            C.event.add(this, "beforeactivate._change", function(e) {
                e = e.target;
                De.test(e.nodeName) && !C._data(e, "change") && (C.event.add(e, "change._change", function(e) {
                    !this.parentNode || e.isSimulated || e.isTrigger || C.event.simulate("change", this.parentNode, e)
                }), C._data(e, "change", !0))
            })
        },
        handle: function(e) {
            var t = e.target;
            if (this !== t || e.isSimulated || e.isTrigger || "radio" !== t.type && "checkbox" !== t.type) return e.handleObj.handler.apply(this, arguments)
        },
        teardown: function() {
            return C.event.remove(this, "._change"), !De.test(this.nodeName)
        }
    }), y.focusin || C.each({
        focus: "focusin",
        blur: "focusout"
    }, function(n, r) {
        var i = function(e) {
                C.event.simulate(r, e.target, C.event.fix(e))
            };
        C.event.special[r] = {
            setup: function() {
                var e = this.ownerDocument || this,
                    t = C._data(e, r);
                t || e.addEventListener(n, i, !0), C._data(e, r, (t || 0) + 1)
            },
            teardown: function() {
                var e = this.ownerDocument || this,
                    t = C._data(e, r) - 1;
                t ? C._data(e, r, t) : (e.removeEventListener(n, i, !0), C._removeData(e, r))
            }
        }
    }), C.fn.extend({
        on: function(e, t, n, r) {
            return Me(this, e, t, n, r)
        },
        one: function(e, t, n, r) {
            return Me(this, e, t, n, r, 1)
        },
        off: function(e, t, n) {
            var r, i;
            if (e && e.preventDefault && e.handleObj) return r = e.handleObj, C(e.delegateTarget).off(r.namespace ? r.origType + "." + r.namespace : r.origType, r.selector, r.handler), this;
            if ("object" != typeof e) return !1 !== t && "function" != typeof t || (n = t, t = undefined), !1 === n && (n = u), this.each(function() {
                C.event.remove(this, e, n, t)
            });
            for (i in e) this.off(i, t, e[i]);
            return this
        },
        trigger: function(e, t) {
            return this.each(function() {
                C.event.trigger(e, t, this)
            })
        },
        triggerHandler: function(e, t) {
            var n = this[0];
            if (n) return C.event.trigger(e, t, n, !0)
        }
    });
    var Oe = / jQuery\d+="(?:null|\d+)"/g,
        Re = new RegExp("<(?:" + xe + ")[\\s/>]", "i"),
        Pe = /<(?!area|br|col|embed|hr|img|input|link|meta|param)(([\w:-]+)[^>]*)\/>/gi,
        Be = /<script|<style|<link/i,
        We = /checked\s*(?:[^=]|=\s*.checked.)/i,
        Ie = /^true\/(.*)/,
        $e = /^\s*<!(?:\[CDATA\[|--)|(?:\]\]|--)>\s*$/g,
        ze = be(g).appendChild(g.createElement("div"));

    function Xe(e, t) {
        return C.nodeName(e, "table") && C.nodeName(11 !== t.nodeType ? t : t.firstChild, "tr") ? e.getElementsByTagName("tbody")[0] || e.appendChild(e.ownerDocument.createElement("tbody")) : e
    }
    function Ue(e) {
        return e.type = (null !== C.find.attr(e, "type")) + "/" + e.type, e
    }
    function Ve(e) {
        var t = Ie.exec(e.type);
        return t ? e.type = t[1] : e.removeAttribute("type"), e
    }
    function Ye(e, t) {
        if (1 === t.nodeType && C.hasData(e)) {
            var n, r, i, e = C._data(e),
                o = C._data(t, e),
                a = e.events;
            if (a) for (n in delete o.handle, o.events = {}, a) for (r = 0, i = a[n].length; r < i; r++) C.event.add(t, n, a[n][r]);
            o.data && (o.data = C.extend({}, o.data))
        }
    }
    function w(n, r, i, o) {
        r = O.apply([], r);
        var e, t, a, s, u, l, c = 0,
            f = n.length,
            d = f - 1,
            p = r[0],
            h = C.isFunction(p);
        if (h || 1 < f && "string" == typeof p && !y.checkClone && We.test(p)) return n.each(function(e) {
            var t = n.eq(e);
            h && (r[0] = p.call(this, e, t.html())), w(t, r, i, o)
        });
        if (f && (e = (l = Ne(r, n[0].ownerDocument, !1, n, o)).firstChild, 1 === l.childNodes.length && (l = e), e || o)) {
            for (a = (s = C.map(b(l, "script"), Ue)).length; c < f; c++) t = l, c !== d && (t = C.clone(t, !0, !0), a && C.merge(s, b(t, "script"))), i.call(n[c], t, c);
            if (a) for (u = s[s.length - 1].ownerDocument, C.map(s, Ve), c = 0; c < a; c++) t = s[c], ye.test(t.type || "") && !C._data(t, "globalEval") && C.contains(u, t) && (t.src ? C._evalUrl && C._evalUrl(t.src) : C.globalEval((t.text || t.textContent || t.innerHTML || "").replace($e, "")));
            l = e = null
        }
        return n
    }
    function Je(e, t, n) {
        for (var r, i = t ? C.filter(t, e) : e, o = 0; null != (r = i[o]); o++) n || 1 !== r.nodeType || C.cleanData(b(r)), r.parentNode && (n && C.contains(r.ownerDocument, r) && we(b(r, "script")), r.parentNode.removeChild(r));
        return e
    }
    C.extend({
        htmlPrefilter: function(e) {
            return e.replace(Pe, "<$1></$2>")
        },
        clone: function(e, t, n) {
            var r, i, o, a, s, u = C.contains(e.ownerDocument, e);
            if (y.html5Clone || C.isXMLDoc(e) || !Re.test("<" + e.nodeName + ">") ? o = e.cloneNode(!0) : (ze.innerHTML = e.outerHTML, ze.removeChild(o = ze.firstChild)), !(y.noCloneEvent && y.noCloneChecked || 1 !== e.nodeType && 11 !== e.nodeType || C.isXMLDoc(e))) for (r = b(o), s = b(e), a = 0; null != (i = s[a]); ++a) if (r[a]) {
                f = c = l = p = d = void 0;
                var l, c, f, d = i,
                    p = r[a];
                if (1 === p.nodeType) {
                    if (l = p.nodeName.toLowerCase(), !y.noCloneEvent && p[C.expando]) {
                        for (c in (f = C._data(p)).events) C.removeEvent(p, c, f.handle);
                        p.removeAttribute(C.expando)
                    }
                    "script" === l && p.text !== d.text ? (Ue(p).text = d.text, Ve(p)) : "object" === l ? (p.parentNode && (p.outerHTML = d.outerHTML), y.html5Clone && d.innerHTML && !C.trim(p.innerHTML) && (p.innerHTML = d.innerHTML)) : "input" === l && ge.test(d.type) ? (p.defaultChecked = p.checked = d.checked, p.value !== d.value && (p.value = d.value)) : "option" === l ? p.defaultSelected = p.selected = d.defaultSelected : "input" !== l && "textarea" !== l || (p.defaultValue = d.defaultValue)
                }
            }
            if (t) if (n) for (s = s || b(e), r = r || b(o), a = 0; null != (i = s[a]); a++) Ye(i, r[a]);
            else Ye(e, o);
            return 0 < (r = b(o, "script")).length && we(r, !u && b(e, "script")), r = s = i = null, o
        },
        cleanData: function(e, t) {
            for (var n, r, i, o, a = 0, s = C.expando, u = C.cache, l = y.attributes, c = C.event.special; null != (n = e[a]); a++) if ((t || v(n)) && (o = (i = n[s]) && u[i])) {
                if (o.events) for (r in o.events) c[r] ? C.event.remove(n, r) : C.removeEvent(n, r, o.handle);
                u[i] && (delete u[i], l || "undefined" == typeof n.removeAttribute ? n[s] = undefined : n.removeAttribute(s), f.push(i))
            }
        }
    }), C.fn.extend({
        domManip: w,
        detach: function(e) {
            return Je(this, e, !0)
        },
        remove: function(e) {
            return Je(this, e)
        },
        text: function(e) {
            return d(this, function(e) {
                return e === undefined ? C.text(this) : this.empty().append((this[0] && this[0].ownerDocument || g).createTextNode(e))
            }, null, e, arguments.length)
        },
        append: function() {
            return w(this, arguments, function(e) {
                1 !== this.nodeType && 11 !== this.nodeType && 9 !== this.nodeType || Xe(this, e).appendChild(e)
            })
        },
        prepend: function() {
            return w(this, arguments, function(e) {
                var t;
                1 !== this.nodeType && 11 !== this.nodeType && 9 !== this.nodeType || (t = Xe(this, e)).insertBefore(e, t.firstChild)
            })
        },
        before: function() {
            return w(this, arguments, function(e) {
                this.parentNode && this.parentNode.insertBefore(e, this)
            })
        },
        after: function() {
            return w(this, arguments, function(e) {
                this.parentNode && this.parentNode.insertBefore(e, this.nextSibling)
            })
        },
        empty: function() {
            for (var e, t = 0; null != (e = this[t]); t++) {
                for (1 === e.nodeType && C.cleanData(b(e, !1)); e.firstChild;) e.removeChild(e.firstChild);
                e.options && C.nodeName(e, "select") && (e.options.length = 0)
            }
            return this
        },
        clone: function(e, t) {
            return e = null != e && e, t = null == t ? e : t, this.map(function() {
                return C.clone(this, e, t)
            })
        },
        html: function(e) {
            return d(this, function(e) {
                var t = this[0] || {},
                    n = 0,
                    r = this.length;
                if (e === undefined) return 1 === t.nodeType ? t.innerHTML.replace(Oe, "") : undefined;
                if ("string" == typeof e && !Be.test(e) && (y.htmlSerialize || !Re.test(e)) && (y.leadingWhitespace || !ve.test(e)) && !x[(me.exec(e) || ["", ""])[1].toLowerCase()]) {
                    e = C.htmlPrefilter(e);
                    try {
                        for (; n < r; n++) 1 === (t = this[n] || {}).nodeType && (C.cleanData(b(t, !1)), t.innerHTML = e);
                        t = 0
                    } catch (i) {}
                }
                t && this.empty().append(e)
            }, null, e, arguments.length)
        },
        replaceWith: function() {
            var n = [];
            return w(this, arguments, function(e) {
                var t = this.parentNode;
                C.inArray(this, n) < 0 && (C.cleanData(b(this)), t && t.replaceChild(e, this))
            }, n)
        }
    }), C.each({
        appendTo: "append",
        prependTo: "prepend",
        insertBefore: "before",
        insertAfter: "after",
        replaceAll: "replaceWith"
    }, function(e, a) {
        C.fn[e] = function(e) {
            for (var t, n = 0, r = [], i = C(e), o = i.length - 1; n <= o; n++) t = n === o ? this : this.clone(!0), C(i[n])[a](t), R.apply(r, t.get());
            return this.pushStack(r)
        }
    });
    var Ge, Ke = {
        HTML: "block",
        BODY: "block"
    };

    function Qe(e, t) {
        e = C(t.createElement(e)).appendTo(t.body), t = C.css(e[0], "display");
        return e.detach(), t
    }
    function Ze(e) {
        var t = g,
            n = Ke[e];
        return n || ("none" !== (n = Qe(e, t)) && n || ((t = ((Ge = (Ge || C("<iframe frameborder='0' width='0' height='0'/>")).appendTo(t.documentElement))[0].contentWindow || Ge[0].contentDocument).document).write(), t.close(), n = Qe(e, t), Ge.detach()), Ke[e] = n), n
    }
    var n, et, tt, nt, rt, it, ot, a, at = /^margin/,
        st = new RegExp("^(" + e + ")(?!px)[a-z%]+$", "i"),
        ut = function(e, t, n, r) {
            var i, o = {};
            for (i in t) o[i] = e.style[i], e.style[i] = t[i];
            for (i in r = n.apply(e, r || []), t) e.style[i] = o[i];
            return r
        },
        lt = g.documentElement;

    function t() {
        var e, t = g.documentElement;
        t.appendChild(ot), a.style.cssText = "-webkit-box-sizing:border-box;box-sizing:border-box;position:relative;display:block;margin:auto;border:1px;padding:1px;top:1%;width:50%", n = tt = it = !1, et = rt = !0, T.getComputedStyle && (e = T.getComputedStyle(a), n = "1%" !== (e || {}).top, it = "2px" === (e || {}).marginLeft, tt = "4px" === (e || {
            width: "4px"
        }).width, a.style.marginRight = "50%", et = "4px" === (e || {
            marginRight: "4px"
        }).marginRight, (e = a.appendChild(g.createElement("div"))).style.cssText = a.style.cssText = "-webkit-box-sizing:content-box;-moz-box-sizing:content-box;box-sizing:content-box;display:block;margin:0;border:0;padding:0", e.style.marginRight = e.style.width = "0", a.style.width = "1px", rt = !parseFloat((T.getComputedStyle(e) || {}).marginRight), a.removeChild(e)), a.style.display = "none", (nt = 0 === a.getClientRects().length) && (a.style.display = "", a.innerHTML = "<table><tr><td></td><td>t</td></tr></table>", a.childNodes[0].style.borderCollapse = "separate", (e = a.getElementsByTagName("td"))[0].style.cssText = "margin:0;border:0;padding:0;display:none", (nt = 0 === e[0].offsetHeight) && (e[0].style.display = "", e[1].style.display = "none", nt = 0 === e[0].offsetHeight)), t.removeChild(ot)
    }
    ot = g.createElement("div"), (a = g.createElement("div")).style && (a.style.cssText = "float:left;opacity:.5", y.opacity = "0.5" === a.style.opacity, y.cssFloat = !! a.style.cssFloat, a.style.backgroundClip = "content-box", a.cloneNode(!0).style.backgroundClip = "", y.clearCloneStyle = "content-box" === a.style.backgroundClip, (ot = g.createElement("div")).style.cssText = "border:0;width:8px;height:0;top:0;left:-9999px;padding:0;margin-top:1px;position:absolute", a.innerHTML = "", ot.appendChild(a), y.boxSizing = "" === a.style.boxSizing || "" === a.style.MozBoxSizing || "" === a.style.WebkitBoxSizing, C.extend(y, {
        reliableHiddenOffsets: function() {
            return null == n && t(), nt
        },
        boxSizingReliable: function() {
            return null == n && t(), tt
        },
        pixelMarginRight: function() {
            return null == n && t(), et
        },
        pixelPosition: function() {
            return null == n && t(), n
        },
        reliableMarginRight: function() {
            return null == n && t(), rt
        },
        reliableMarginLeft: function() {
            return null == n && t(), it
        }
    }));
    var l, p, ct = /^(top|right|bottom|left)$/;

    function ft(e, t) {
        return {
            get: function() {
                if (!e()) return (this.get = t).apply(this, arguments);
                delete this.get
            }
        }
    }
    T.getComputedStyle ? (l = function(e) {
        var t = e.ownerDocument.defaultView;
        return (t = t && t.opener ? t : T).getComputedStyle(e)
    }, p = function(e, t, n) {
        var r, i, o = e.style;
        return "" !== (i = (n = n || l(e)) ? n.getPropertyValue(t) || n[t] : undefined) && i !== undefined || C.contains(e.ownerDocument, e) || (i = C.style(e, t)), n && !y.pixelMarginRight() && st.test(i) && at.test(t) && (e = o.width, t = o.minWidth, r = o.maxWidth, o.minWidth = o.maxWidth = o.width = i, i = n.width, o.width = e, o.minWidth = t, o.maxWidth = r), i === undefined ? i : i + ""
    }) : lt.currentStyle && (l = function(e) {
        return e.currentStyle
    }, p = function(e, t, n) {
        var r, i, o, a = e.style;
        return null == (n = (n = n || l(e)) ? n[t] : undefined) && a && a[t] && (n = a[t]), st.test(n) && !ct.test(t) && (r = a.left, (o = (i = e.runtimeStyle) && i.left) && (i.left = e.currentStyle.left), a.left = "fontSize" === t ? "1em" : n, n = a.pixelLeft + "px", a.left = r, o && (i.left = o)), n === undefined ? n : n + "" || "auto"
    });
    var dt = /alpha\([^)]*\)/i,
        pt = /opacity\s*=\s*([^)]*)/i,
        ht = /^(none|table(?!-c[ea]).+)/,
        gt = new RegExp("^(" + e + ")(.*)$", "i"),
        mt = {
            position: "absolute",
            visibility: "hidden",
            display: "block"
        },
        yt = {
            letterSpacing: "0",
            fontWeight: "400"
        },
        vt = ["Webkit", "O", "Moz", "ms"],
        xt = g.createElement("div").style;

    function bt(e) {
        if (e in xt) return e;
        for (var t = e.charAt(0).toUpperCase() + e.slice(1), n = vt.length; n--;) if ((e = vt[n] + t) in xt) return e
    }
    function wt(e, t) {
        for (var n, r, i, o = [], a = 0, s = e.length; a < s; a++)(r = e[a]).style && (o[a] = C._data(r, "olddisplay"), n = r.style.display, t ? (o[a] || "none" !== n || (r.style.display = ""), "" === r.style.display && pe(r) && (o[a] = C._data(r, "olddisplay", Ze(r.nodeName)))) : (i = pe(r), (n && "none" !== n || !i) && C._data(r, "olddisplay", i ? n : C.css(r, "display"))));
        for (a = 0; a < s; a++)!(r = e[a]).style || t && "none" !== r.style.display && "" !== r.style.display || (r.style.display = t ? o[a] || "" : "none");
        return e
    }
    function Tt(e, t, n) {
        var r = gt.exec(t);
        return r ? Math.max(0, r[1] - (n || 0)) + (r[2] || "px") : t
    }
    function Ct(e, t, n, r, i) {
        for (var o = n === (r ? "border" : "content") ? 4 : "width" === t ? 1 : 0, a = 0; o < 4; o += 2)"margin" === n && (a += C.css(e, n + s[o], !0, i)), r ? ("content" === n && (a -= C.css(e, "padding" + s[o], !0, i)), "margin" !== n && (a -= C.css(e, "border" + s[o] + "Width", !0, i))) : (a += C.css(e, "padding" + s[o], !0, i), "padding" !== n && (a += C.css(e, "border" + s[o] + "Width", !0, i)));
        return a
    }
    function Et(e, t, n) {
        var r = !0,
            i = "width" === t ? e.offsetWidth : e.offsetHeight,
            o = l(e),
            a = y.boxSizing && "border-box" === C.css(e, "boxSizing", !1, o);
        if (i <= 0 || null == i) {
            if (((i = p(e, t, o)) < 0 || null == i) && (i = e.style[t]), st.test(i)) return i;
            r = a && (y.boxSizingReliable() || i === e.style[t]), i = parseFloat(i) || 0
        }
        return i + Ct(e, t, n || (a ? "border" : "content"), r, o) + "px"
    }
    function h(e, t, n, r, i) {
        return new h.prototype.init(e, t, n, r, i)
    }
    C.extend({
        cssHooks: {
            opacity: {
                get: function(e, t) {
                    if (t) return "" === (t = p(e, "opacity")) ? "1" : t
                }
            }
        },
        cssNumber: {
            animationIterationCount: !0,
            columnCount: !0,
            fillOpacity: !0,
            flexGrow: !0,
            flexShrink: !0,
            fontWeight: !0,
            lineHeight: !0,
            opacity: !0,
            order: !0,
            orphans: !0,
            widows: !0,
            zIndex: !0,
            zoom: !0
        },
        cssProps: {
            "float": y.cssFloat ? "cssFloat" : "styleFloat"
        },
        style: function(e, t, n, r) {
            if (e && 3 !== e.nodeType && 8 !== e.nodeType && e.style) {
                var i, o, a, s = C.camelCase(t),
                    u = e.style;
                if (t = C.cssProps[s] || (C.cssProps[s] = bt(s) || s), a = C.cssHooks[t] || C.cssHooks[s], n === undefined) return a && "get" in a && (i = a.get(e, !1, r)) !== undefined ? i : u[t];
                if ("string" === (o = typeof n) && (i = de.exec(n)) && i[1] && (n = he(e, t, i), o = "number"), null != n && n == n && ("number" === o && (n += i && i[3] || (C.cssNumber[s] ? "" : "px")), y.clearCloneStyle || "" !== n || 0 !== t.indexOf("background") || (u[t] = "inherit"), !(a && "set" in a && (n = a.set(e, n, r)) === undefined))) try {
                    u[t] = n
                } catch (l) {}
            }
        },
        css: function(e, t, n, r) {
            var i, o = C.camelCase(t);
            return t = C.cssProps[o] || (C.cssProps[o] = bt(o) || o), "normal" === (i = (i = (o = C.cssHooks[t] || C.cssHooks[o]) && "get" in o ? o.get(e, !0, n) : i) === undefined ? p(e, t, r) : i) && t in yt && (i = yt[t]), "" === n || n ? (o = parseFloat(i), !0 === n || isFinite(o) ? o || 0 : i) : i
        }
    }), C.each(["height", "width"], function(e, i) {
        C.cssHooks[i] = {
            get: function(e, t, n) {
                if (t) return ht.test(C.css(e, "display")) && 0 === e.offsetWidth ? ut(e, mt, function() {
                    return Et(e, i, n)
                }) : Et(e, i, n)
            },
            set: function(e, t, n) {
                var r = n && l(e);
                return Tt(0, t, n ? Ct(e, i, n, y.boxSizing && "border-box" === C.css(e, "boxSizing", !1, r), r) : 0)
            }
        }
    }), y.opacity || (C.cssHooks.opacity = {
        get: function(e, t) {
            return pt.test((t && e.currentStyle ? e.currentStyle : e.style).filter || "") ? .01 * parseFloat(RegExp.$1) + "" : t ? "1" : ""
        },
        set: function(e, t) {
            var n = e.style,
                e = e.currentStyle,
                r = C.isNumeric(t) ? "alpha(opacity=" + 100 * t + ")" : "",
                i = e && e.filter || n.filter || "";
            ((n.zoom = 1) <= t || "" === t) && "" === C.trim(i.replace(dt, "")) && n.removeAttribute && (n.removeAttribute("filter"), "" === t || e && !e.filter) || (n.filter = dt.test(i) ? i.replace(dt, r) : i + " " + r)
        }
    }), C.cssHooks.marginRight = ft(y.reliableMarginRight, function(e, t) {
        if (t) return ut(e, {
            display: "inline-block"
        }, p, [e, "marginRight"])
    }), C.cssHooks.marginLeft = ft(y.reliableMarginLeft, function(e, t) {
        if (t) return (parseFloat(p(e, "marginLeft")) || (C.contains(e.ownerDocument, e) ? e.getBoundingClientRect().left - ut(e, {
            marginLeft: 0
        }, function() {
            return e.getBoundingClientRect().left
        }) : 0)) + "px"
    }), C.each({
        margin: "",
        padding: "",
        border: "Width"
    }, function(i, o) {
        C.cssHooks[i + o] = {
            expand: function(e) {
                for (var t = 0, n = {}, r = "string" == typeof e ? e.split(" ") : [e]; t < 4; t++) n[i + s[t] + o] = r[t] || r[t - 2] || r[0];
                return n
            }
        }, at.test(i) || (C.cssHooks[i + o].set = Tt)
    }), C.fn.extend({
        css: function(e, t) {
            return d(this, function(e, t, n) {
                var r, i, o = {},
                    a = 0;
                if (C.isArray(t)) {
                    for (r = l(e), i = t.length; a < i; a++) o[t[a]] = C.css(e, t[a], !1, r);
                    return o
                }
                return n !== undefined ? C.style(e, t, n) : C.css(e, t)
            }, e, t, 1 < arguments.length)
        },
        show: function() {
            return wt(this, !0)
        },
        hide: function() {
            return wt(this)
        },
        toggle: function(e) {
            return "boolean" == typeof e ? e ? this.show() : this.hide() : this.each(function() {
                pe(this) ? C(this).show() : C(this).hide()
            })
        }
    }), ((C.Tween = h).prototype = {
        constructor: h,
        init: function(e, t, n, r, i, o) {
            this.elem = e, this.prop = n, this.easing = i || C.easing._default, this.options = t, this.start = this.now = this.cur(), this.end = r, this.unit = o || (C.cssNumber[n] ? "" : "px")
        },
        cur: function() {
            var e = h.propHooks[this.prop];
            return (e && e.get ? e : h.propHooks._default).get(this)
        },
        run: function(e) {
            var t, n = h.propHooks[this.prop];
            return this.options.duration ? this.pos = t = C.easing[this.easing](e, this.options.duration * e, 0, 1, this.options.duration) : this.pos = t = e, this.now = (this.end - this.start) * t + this.start, this.options.step && this.options.step.call(this.elem, this.now, this), (n && n.set ? n : h.propHooks._default).set(this), this
        }
    }).init.prototype = h.prototype, (h.propHooks = {
        _default: {
            get: function(e) {
                return 1 !== e.elem.nodeType || null != e.elem[e.prop] && null == e.elem.style[e.prop] ? e.elem[e.prop] : (e = C.css(e.elem, e.prop, "")) && "auto" !== e ? e : 0
            },
            set: function(e) {
                C.fx.step[e.prop] ? C.fx.step[e.prop](e) : 1 !== e.elem.nodeType || null == e.elem.style[C.cssProps[e.prop]] && !C.cssHooks[e.prop] ? e.elem[e.prop] = e.now : C.style(e.elem, e.prop, e.now + e.unit)
            }
        }
    }).scrollTop = h.propHooks.scrollLeft = {
        set: function(e) {
            e.elem.nodeType && e.elem.parentNode && (e.elem[e.prop] = e.now)
        }
    }, C.easing = {
        linear: function(e) {
            return e
        },
        swing: function(e) {
            return .5 - Math.cos(e * Math.PI) / 2
        },
        _default: "swing"
    }, C.fx = h.prototype.init, C.fx.step = {};
    var N, Nt, k, S, kt = /^(?:toggle|show|hide)$/,
        St = /queueHooks$/;

    function At() {
        return T.setTimeout(function() {
            N = undefined
        }), N = C.now()
    }
    function Dt(e, t) {
        var n, r = {
            height: e
        },
            i = 0;
        for (t = t ? 1 : 0; i < 4; i += 2 - t) r["margin" + (n = s[i])] = r["padding" + n] = e;
        return t && (r.opacity = r.width = e), r
    }
    function jt(e, t, n) {
        for (var r, i = (A.tweeners[t] || []).concat(A.tweeners["*"]), o = 0, a = i.length; o < a; o++) if (r = i[o].call(n, t, e)) return r
    }
    function A(i, e, t) {
        var n, o, r, a, s, u, l, c = 0,
            f = A.prefilters.length,
            d = C.Deferred().always(function() {
                delete p.elem
            }),
            p = function() {
                if (o) return !1;
                for (var e = N || At(), e = Math.max(0, h.startTime + h.duration - e), t = 1 - (e / h.duration || 0), n = 0, r = h.tweens.length; n < r; n++) h.tweens[n].run(t);
                return d.notifyWith(i, [h, t, e]), t < 1 && r ? e : (d.resolveWith(i, [h]), !1)
            },
            h = d.promise({
                elem: i,
                props: C.extend({}, e),
                opts: C.extend(!0, {
                    specialEasing: {},
                    easing: C.easing._default
                }, t),
                originalProperties: e,
                originalOptions: t,
                startTime: N || At(),
                duration: t.duration,
                tweens: [],
                createTween: function(e, t) {
                    t = C.Tween(i, h.opts, e, t, h.opts.specialEasing[e] || h.opts.easing);
                    return h.tweens.push(t), t
                },
                stop: function(e) {
                    var t = 0,
                        n = e ? h.tweens.length : 0;
                    if (o) return this;
                    for (o = !0; t < n; t++) h.tweens[t].run(1);
                    return e ? (d.notifyWith(i, [h, 1, 0]), d.resolveWith(i, [h, e])) : d.rejectWith(i, [h, e]), this
                }
            }),
            g = h.props,
            m = g,
            y = h.opts.specialEasing;
        for (r in m) if (s = y[a = C.camelCase(r)], u = m[r], C.isArray(u) && (s = u[1], u = m[r] = u[0]), r !== a && (m[a] = u, delete m[r]), (l = C.cssHooks[a]) && "expand" in l) for (r in u = l.expand(u), delete m[a], u) r in m || (m[r] = u[r], y[r] = s);
        else y[a] = s;
        for (; c < f; c++) if (n = A.prefilters[c].call(h, i, g, h.opts)) return C.isFunction(n.stop) && (C._queueHooks(h.elem, h.opts.queue).stop = C.proxy(n.stop, n)), n;
        return C.map(g, jt, h), C.isFunction(h.opts.start) && h.opts.start.call(i, h), C.fx.timer(C.extend(p, {
            elem: i,
            anim: h,
            queue: h.opts.queue
        })), h.progress(h.opts.progress).done(h.opts.done, h.opts.complete).fail(h.opts.fail).always(h.opts.always)
    }
    C.Animation = C.extend(A, {
        tweeners: {
            "*": [function(e, t) {
                var n = this.createTween(e, t);
                return he(n.elem, e, de.exec(t), n), n
            }]
        },
        tweener: function(e, t) {
            for (var n, r = 0, i = (e = C.isFunction(e) ? (t = e, ["*"]) : e.match(E)).length; r < i; r++) n = e[r], A.tweeners[n] = A.tweeners[n] || [], A.tweeners[n].unshift(t)
        },
        prefilters: [function(t, e, n) {
            var r, i, o, a, s, u, l, c = this,
                f = {},
                d = t.style,
                p = t.nodeType && pe(t),
                h = C._data(t, "fxshow");
            for (r in n.queue || (null == (s = C._queueHooks(t, "fx")).unqueued && (s.unqueued = 0, u = s.empty.fire, s.empty.fire = function() {
                s.unqueued || u()
            }), s.unqueued++, c.always(function() {
                c.always(function() {
                    s.unqueued--, C.queue(t, "fx").length || s.empty.fire()
                })
            })), 1 === t.nodeType && ("height" in e || "width" in e) && (n.overflow = [d.overflow, d.overflowX, d.overflowY], "inline" === ("none" === (l = C.css(t, "display")) ? C._data(t, "olddisplay") || Ze(t.nodeName) : l) && "none" === C.css(t, "float") && (y.inlineBlockNeedsLayout && "inline" !== Ze(t.nodeName) ? d.zoom = 1 : d.display = "inline-block")), n.overflow && (d.overflow = "hidden", y.shrinkWrapBlocks() || c.always(function() {
                d.overflow = n.overflow[0], d.overflowX = n.overflow[1], d.overflowY = n.overflow[2]
            })), e) if (i = e[r], kt.exec(i)) {
                if (delete e[r], o = o || "toggle" === i, i === (p ? "hide" : "show")) {
                    if ("show" !== i || !h || h[r] === undefined) continue;
                    p = !0
                }
                f[r] = h && h[r] || C.style(t, r)
            } else l = undefined;
            if (C.isEmptyObject(f))"inline" === ("none" === l ? Ze(t.nodeName) : l) && (d.display = l);
            else for (r in h ? "hidden" in h && (p = h.hidden) : h = C._data(t, "fxshow", {}), o && (h.hidden = !p), p ? C(t).show() : c.done(function() {
                C(t).hide()
            }), c.done(function() {
                for (var e in C._removeData(t, "fxshow"), f) C.style(t, e, f[e])
            }), f) a = jt(p ? h[r] : 0, r, c), r in h || (h[r] = a.start, p && (a.end = a.start, a.start = "width" === r || "height" === r ? 1 : 0))
        }],
        prefilter: function(e, t) {
            t ? A.prefilters.unshift(e) : A.prefilters.push(e)
        }
    }), C.speed = function(e, t, n) {
        var r = e && "object" == typeof e ? C.extend({}, e) : {
            complete: n || !n && t || C.isFunction(e) && e,
            duration: e,
            easing: n && t || t && !C.isFunction(t) && t
        };
        return r.duration = C.fx.off ? 0 : "number" == typeof r.duration ? r.duration : r.duration in C.fx.speeds ? C.fx.speeds[r.duration] : C.fx.speeds._default, null != r.queue && !0 !== r.queue || (r.queue = "fx"), r.old = r.complete, r.complete = function() {
            C.isFunction(r.old) && r.old.call(this), r.queue && C.dequeue(this, r.queue)
        }, r
    }, C.fn.extend({
        fadeTo: function(e, t, n, r) {
            return this.filter(pe).css("opacity", 0).show().end().animate({
                opacity: t
            }, e, n, r)
        },
        animate: function(t, e, n, r) {
            var i = C.isEmptyObject(t),
                o = C.speed(e, n, r),
                e = function() {
                    var e = A(this, C.extend({}, t), o);
                    (i || C._data(this, "finish")) && e.stop(!0)
                };
            return e.finish = e, i || !1 === o.queue ? this.each(e) : this.queue(o.queue, e)
        },
        stop: function(i, e, o) {
            var a = function(e) {
                    var t = e.stop;
                    delete e.stop, t(o)
                };
            return "string" != typeof i && (o = e, e = i, i = undefined), e && !1 !== i && this.queue(i || "fx", []), this.each(function() {
                var e = !0,
                    t = null != i && i + "queueHooks",
                    n = C.timers,
                    r = C._data(this);
                if (t) r[t] && r[t].stop && a(r[t]);
                else for (t in r) r[t] && r[t].stop && St.test(t) && a(r[t]);
                for (t = n.length; t--;) n[t].elem !== this || null != i && n[t].queue !== i || (n[t].anim.stop(o), e = !1, n.splice(t, 1));
                !e && o || C.dequeue(this, i)
            })
        },
        finish: function(a) {
            return !1 !== a && (a = a || "fx"), this.each(function() {
                var e, t = C._data(this),
                    n = t[a + "queue"],
                    r = t[a + "queueHooks"],
                    i = C.timers,
                    o = n ? n.length : 0;
                for (t.finish = !0, C.queue(this, a, []), r && r.stop && r.stop.call(this, !0), e = i.length; e--;) i[e].elem === this && i[e].queue === a && (i[e].anim.stop(!0), i.splice(e, 1));
                for (e = 0; e < o; e++) n[e] && n[e].finish && n[e].finish.call(this);
                delete t.finish
            })
        }
    }), C.each(["toggle", "show", "hide"], function(e, r) {
        var i = C.fn[r];
        C.fn[r] = function(e, t, n) {
            return null == e || "boolean" == typeof e ? i.apply(this, arguments) : this.animate(Dt(r, !0), e, t, n)
        }
    }), C.each({
        slideDown: Dt("show"),
        slideUp: Dt("hide"),
        slideToggle: Dt("toggle"),
        fadeIn: {
            opacity: "show"
        },
        fadeOut: {
            opacity: "hide"
        },
        fadeToggle: {
            opacity: "toggle"
        }
    }, function(e, r) {
        C.fn[e] = function(e, t, n) {
            return this.animate(r, e, t, n)
        }
    }), C.timers = [], C.fx.tick = function() {
        var e, t = C.timers,
            n = 0;
        for (N = C.now(); n < t.length; n++)(e = t[n])() || t[n] !== e || t.splice(n--, 1);
        t.length || C.fx.stop(), N = undefined
    }, C.fx.timer = function(e) {
        C.timers.push(e), e() ? C.fx.start() : C.timers.pop()
    }, C.fx.interval = 13, C.fx.start = function() {
        Nt = Nt || T.setInterval(C.fx.tick, C.fx.interval)
    }, C.fx.stop = function() {
        T.clearInterval(Nt), Nt = null
    }, C.fx.speeds = {
        slow: 600,
        fast: 200,
        _default: 400
    }, C.fn.delay = function(r, e) {
        return r = C.fx && C.fx.speeds[r] || r, this.queue(e = e || "fx", function(e, t) {
            var n = T.setTimeout(e, r);
            t.stop = function() {
                T.clearTimeout(n)
            }
        })
    }, k = g.createElement("input"), q = g.createElement("div"), S = g.createElement("select"), e = S.appendChild(g.createElement("option")), (q = g.createElement("div")).setAttribute("className", "t"), q.innerHTML = "  <link/><table></table><a href='/a'>a</a><input type='checkbox'/>", F = q.getElementsByTagName("a")[0], k.setAttribute("type", "checkbox"), q.appendChild(k), (F = q.getElementsByTagName("a")[0]).style.cssText = "top:1px", y.getSetAttribute = "t" !== q.className, y.style = /top/.test(F.getAttribute("style")), y.hrefNormalized = "/a" === F.getAttribute("href"), y.checkOn = !! k.value, y.optSelected = e.selected, y.enctype = !! g.createElement("form").enctype, S.disabled = !0, y.optDisabled = !e.disabled, (k = g.createElement("input")).setAttribute("value", ""), y.input = "" === k.getAttribute("value"), k.value = "t", k.setAttribute("type", "radio"), y.radioValue = "t" === k.value;
    var Lt = /\r/g,
        Ht = /[\x20\t\r\n\f]+/g;
    C.fn.extend({
        val: function(t) {
            var n, e, r, i = this[0];
            return arguments.length ? (r = C.isFunction(t), this.each(function(e) {
                1 === this.nodeType && (null == (e = r ? t.call(this, e, C(this).val()) : t) ? e = "" : "number" == typeof e ? e += "" : C.isArray(e) && (e = C.map(e, function(e) {
                    return null == e ? "" : e + ""
                })), (n = C.valHooks[this.type] || C.valHooks[this.nodeName.toLowerCase()]) && "set" in n && n.set(this, e, "value") !== undefined || (this.value = e))
            })) : i ? (n = C.valHooks[i.type] || C.valHooks[i.nodeName.toLowerCase()]) && "get" in n && (e = n.get(i, "value")) !== undefined ? e : "string" == typeof(e = i.value) ? e.replace(Lt, "") : null == e ? "" : e : void 0
        }
    }), C.extend({
        valHooks: {
            option: {
                get: function(e) {
                    var t = C.find.attr(e, "value");
                    return null != t ? t : C.trim(C.text(e)).replace(Ht, " ")
                }
            },
            select: {
                get: function(e) {
                    for (var t, n = e.options, r = e.selectedIndex, i = "select-one" === e.type || r < 0, o = i ? null : [], a = i ? r + 1 : n.length, s = r < 0 ? a : i ? r : 0; s < a; s++) if (((t = n[s]).selected || s === r) && (y.optDisabled ? !t.disabled : null === t.getAttribute("disabled")) && (!t.parentNode.disabled || !C.nodeName(t.parentNode, "optgroup"))) {
                        if (t = C(t).val(), i) return t;
                        o.push(t)
                    }
                    return o
                },
                set: function(e, t) {
                    for (var n, r, i = e.options, o = C.makeArray(t), a = i.length; a--;) if (r = i[a], -1 < C.inArray(C.valHooks.option.get(r), o)) try {
                        r.selected = n = !0
                    } catch (s) {
                        r.scrollHeight
                    } else r.selected = !1;
                    return n || (e.selectedIndex = -1), i
                }
            }
        }
    }), C.each(["radio", "checkbox"], function() {
        C.valHooks[this] = {
            set: function(e, t) {
                if (C.isArray(t)) return e.checked = -1 < C.inArray(C(e).val(), t)
            }
        }, y.checkOn || (C.valHooks[this].get = function(e) {
            return null === e.getAttribute("value") ? "on" : e.value
        })
    });
    var D, qt, j = C.expr.attrHandle,
        _t = /^(?:checked|selected)$/i,
        L = y.getSetAttribute,
        Ft = y.input,
        Mt = (C.fn.extend({
            attr: function(e, t) {
                return d(this, C.attr, e, t, 1 < arguments.length)
            },
            removeAttr: function(e) {
                return this.each(function() {
                    C.removeAttr(this, e)
                })
            }
        }), C.extend({
            attr: function(e, t, n) {
                var r, i, o = e.nodeType;
                if (3 !== o && 8 !== o && 2 !== o) return "undefined" == typeof e.getAttribute ? C.prop(e, t, n) : (1 === o && C.isXMLDoc(e) || (t = t.toLowerCase(), i = C.attrHooks[t] || (C.expr.match.bool.test(t) ? qt : D)), n !== undefined ? null === n ? void C.removeAttr(e, t) : i && "set" in i && (r = i.set(e, n, t)) !== undefined ? r : (e.setAttribute(t, n + ""), n) : !(i && "get" in i && null !== (r = i.get(e, t))) && null == (r = C.find.attr(e, t)) ? undefined : r)
            },
            attrHooks: {
                type: {
                    set: function(e, t) {
                        var n;
                        if (!y.radioValue && "radio" === t && C.nodeName(e, "input")) return n = e.value, e.setAttribute("type", t), n && (e.value = n), t
                    }
                }
            },
            removeAttr: function(e, t) {
                var n, r, i = 0,
                    o = t && t.match(E);
                if (o && 1 === e.nodeType) for (; n = o[i++];) r = C.propFix[n] || n, C.expr.match.bool.test(n) ? Ft && L || !_t.test(n) ? e[r] = !1 : e[C.camelCase("default-" + n)] = e[r] = !1 : C.attr(e, n, ""), e.removeAttribute(L ? n : r)
            }
        }), qt = {
            set: function(e, t, n) {
                return !1 === t ? C.removeAttr(e, n) : Ft && L || !_t.test(n) ? e.setAttribute(!L && C.propFix[n] || n, n) : e[C.camelCase("default-" + n)] = e[n] = !0, n
            }
        }, C.each(C.expr.match.bool.source.match(/\w+/g), function(e, t) {
            var o = j[t] || C.find.attr;
            Ft && L || !_t.test(t) ? j[t] = function(e, t, n) {
                var r, i;
                return n || (i = j[t], j[t] = r, r = null != o(e, t, n) ? t.toLowerCase() : null, j[t] = i), r
            } : j[t] = function(e, t, n) {
                if (!n) return e[C.camelCase("default-" + t)] ? t.toLowerCase() : null
            }
        }), Ft && L || (C.attrHooks.value = {
            set: function(e, t, n) {
                if (!C.nodeName(e, "input")) return D && D.set(e, t, n);
                e.defaultValue = t
            }
        }), L || (D = {
            set: function(e, t, n) {
                var r = e.getAttributeNode(n);
                if (r || e.setAttributeNode(r = e.ownerDocument.createAttribute(n)), r.value = t += "", "value" === n || t === e.getAttribute(n)) return t
            }
        }, j.id = j.name = j.coords = function(e, t, n) {
            if (!n) return (n = e.getAttributeNode(t)) && "" !== n.value ? n.value : null
        }, C.valHooks.button = {
            get: function(e, t) {
                t = e.getAttributeNode(t);
                if (t && t.specified) return t.value
            },
            set: D.set
        }, C.attrHooks.contenteditable = {
            set: function(e, t, n) {
                D.set(e, "" !== t && t, n)
            }
        }, C.each(["width", "height"], function(e, n) {
            C.attrHooks[n] = {
                set: function(e, t) {
                    if ("" === t) return e.setAttribute(n, "auto"), t
                }
            }
        })), y.style || (C.attrHooks.style = {
            get: function(e) {
                return e.style.cssText || undefined
            },
            set: function(e, t) {
                return e.style.cssText = t + ""
            }
        }), /^(?:input|select|textarea|button|object)$/i),
        Ot = /^(?:a|area)$/i,
        Rt = (C.fn.extend({
            prop: function(e, t) {
                return d(this, C.prop, e, t, 1 < arguments.length)
            },
            removeProp: function(t) {
                return t = C.propFix[t] || t, this.each(function() {
                    try {
                        this[t] = undefined, delete this[t]
                    } catch (e) {}
                })
            }
        }), C.extend({
            prop: function(e, t, n) {
                var r, i, o = e.nodeType;
                if (3 !== o && 8 !== o && 2 !== o) return 1 === o && C.isXMLDoc(e) || (t = C.propFix[t] || t, i = C.propHooks[t]), n !== undefined ? i && "set" in i && (r = i.set(e, n, t)) !== undefined ? r : e[t] = n : i && "get" in i && null !== (r = i.get(e, t)) ? r : e[t]
            },
            propHooks: {
                tabIndex: {
                    get: function(e) {
                        var t = C.find.attr(e, "tabindex");
                        return t ? parseInt(t, 10) : Mt.test(e.nodeName) || Ot.test(e.nodeName) && e.href ? 0 : -1
                    }
                }
            },
            propFix: {
                "for": "htmlFor",
                "class": "className"
            }
        }), y.hrefNormalized || C.each(["href", "src"], function(e, t) {
            C.propHooks[t] = {
                get: function(e) {
                    return e.getAttribute(t, 4)
                }
            }
        }), y.optSelected || (C.propHooks.selected = {
            get: function(e) {
                e = e.parentNode;
                return e && (e.selectedIndex, e.parentNode && e.parentNode.selectedIndex), null
            },
            set: function(e) {
                e = e.parentNode;
                e && (e.selectedIndex, e.parentNode && e.parentNode.selectedIndex)
            }
        }), C.each(["tabIndex", "readOnly", "maxLength", "cellSpacing", "cellPadding", "rowSpan", "colSpan", "useMap", "frameBorder", "contentEditable"], function() {
            C.propFix[this.toLowerCase()] = this
        }), y.enctype || (C.propFix.enctype = "encoding"), /[\t\r\n\f]/g);

    function H(e) {
        return C.attr(e, "class") || ""
    }
    C.fn.extend({
        addClass: function(t) {
            var e, n, r, i, o, a, s = 0;
            if (C.isFunction(t)) return this.each(function(e) {
                C(this).addClass(t.call(this, e, H(this)))
            });
            if ("string" == typeof t && t) for (e = t.match(E) || []; n = this[s++];) if (a = H(n), r = 1 === n.nodeType && (" " + a + " ").replace(Rt, " ")) {
                for (o = 0; i = e[o++];) r.indexOf(" " + i + " ") < 0 && (r += i + " ");
                a !== (a = C.trim(r)) && C.attr(n, "class", a)
            }
            return this
        },
        removeClass: function(t) {
            var e, n, r, i, o, a, s = 0;
            if (C.isFunction(t)) return this.each(function(e) {
                C(this).removeClass(t.call(this, e, H(this)))
            });
            if (!arguments.length) return this.attr("class", "");
            if ("string" == typeof t && t) for (e = t.match(E) || []; n = this[s++];) if (a = H(n), r = 1 === n.nodeType && (" " + a + " ").replace(Rt, " ")) {
                for (o = 0; i = e[o++];) for (; - 1 < r.indexOf(" " + i + " ");) r = r.replace(" " + i + " ", " ");
                a !== (a = C.trim(r)) && C.attr(n, "class", a)
            }
            return this
        },
        toggleClass: function(i, t) {
            var o = typeof i;
            return "boolean" == typeof t && "string" == o ? t ? this.addClass(i) : this.removeClass(i) : C.isFunction(i) ? this.each(function(e) {
                C(this).toggleClass(i.call(this, e, H(this), t), t)
            }) : this.each(function() {
                var e, t, n, r;
                if ("string" == o) for (t = 0, n = C(this), r = i.match(E) || []; e = r[t++];) n.hasClass(e) ? n.removeClass(e) : n.addClass(e);
                else i !== undefined && "boolean" != o || ((e = H(this)) && C._data(this, "__className__", e), C.attr(this, "class", !e && !1 !== i && C._data(this, "__className__") || ""))
            })
        },
        hasClass: function(e) {
            for (var t, n = 0, r = " " + e + " "; t = this[n++];) if (1 === t.nodeType && -1 < (" " + H(t) + " ").replace(Rt, " ").indexOf(r)) return !0;
            return !1
        }
    }), C.each("blur focus focusin focusout load resize scroll unload click dblclick mousedown mouseup mousemove mouseover mouseout mouseenter mouseleave change select submit keydown keypress keyup error contextMenu".split(" "), function(e, n) {
        C.fn[n] = function(e, t) {
            return 0 < arguments.length ? this.on(n, null, e, t) : this.trigger(n)
        }
    }), C.fn.extend({
        hover: function(e, t) {
            return this.mouseenter(e).mouseleave(t || e)
        }
    });
    var q = T.location,
        Pt = C.now(),
        Bt = /\?/,
        Wt = /(,)|(\[|{)|(}|])|"(?:[^"\\\r\n]|\\["\\\/bfnrt]|\\u[\da-fA-F]{4})*"\s*:?|true|false|null|-?(?!0\d)\d+(?:\.\d+|)(?:[eE][+-]?\d+|)/g,
        It = (C.parseJSON = function(e) {
            if (T.JSON && T.JSON.parse) return T.JSON.parse(e + "");
            var i, o = null,
                t = C.trim(e + "");
            return t && !C.trim(t.replace(Wt, function(e, t, n, r) {
                return 0 === (o = i && t ? 0 : o) ? e : (i = n || t, o += !r - !n, "")
            })) ? Function("return " + t)() : C.error("Invalid JSON: " + e)
        }, C.parseXML = function(e) {
            var t;
            if (!e || "string" != typeof e) return null;
            try {
                T.DOMParser ? t = (new T.DOMParser).parseFromString(e, "text/xml") : ((t = new T.ActiveXObject("Microsoft.XMLDOM"))["async"] = "false", t.loadXML(e))
            } catch (n) {
                t = undefined
            }
            return t && t.documentElement && !t.getElementsByTagName("parsererror").length || C.error("Invalid XML: " + e), t
        }, /#.*$/),
        $t = /([?&])_=[^&]*/,
        zt = /^(.*?):[ \t]*([^\r\n]*)\r?$/gm,
        Xt = /^(?:GET|HEAD)$/,
        Ut = /^\/\//,
        Vt = /^([\w.+-]+:)(?:\/\/(?:[^\/?#]*@|)([^\/?#:]*)(?::(\d+)|)|)/,
        Yt = {},
        Jt = {},
        Gt = "*/".concat("*"),
        Kt = q.href,
        _ = Vt.exec(Kt.toLowerCase()) || [];

    function Qt(o) {
        return function(e, t) {
            "string" != typeof e && (t = e, e = "*");
            var n, r = 0,
                i = e.toLowerCase().match(E) || [];
            if (C.isFunction(t)) for (; n = i[r++];)"+" === n.charAt(0) ? (n = n.slice(1) || "*", (o[n] = o[n] || []).unshift(t)) : (o[n] = o[n] || []).push(t)
        }
    }
    function Zt(t, r, i, o) {
        var a = {},
            s = t === Jt;

        function u(e) {
            var n;
            return a[e] = !0, C.each(t[e] || [], function(e, t) {
                t = t(r, i, o);
                return "string" != typeof t || s || a[t] ? s ? !(n = t) : void 0 : (r.dataTypes.unshift(t), u(t), !1)
            }), n
        }
        return u(r.dataTypes[0]) || !a["*"] && u("*")
    }
    function en(e, t) {
        var n, r, i = C.ajaxSettings.flatOptions || {};
        for (r in t) t[r] !== undefined && ((i[r] ? e : n = n || {})[r] = t[r]);
        return n && C.extend(!0, e, n), e
    }
    function tn(e, t, n, r) {
        var i, o, a, s, u, l = {},
            c = e.dataTypes.slice();
        if (c[1]) for (a in e.converters) l[a.toLowerCase()] = e.converters[a];
        for (o = c.shift(); o;) if (e.responseFields[o] && (n[e.responseFields[o]] = t), !u && r && e.dataFilter && (t = e.dataFilter(t, e.dataType)), u = o, o = c.shift()) if ("*" === o) o = u;
        else if ("*" !== u && u !== o) {
            if (!(a = l[u + " " + o] || l["* " + o])) for (i in l) if ((s = i.split(" "))[1] === o && (a = l[u + " " + s[0]] || l["* " + s[0]])) {
                !0 === a ? a = l[i] : !0 !== l[i] && (o = s[0], c.unshift(s[1]));
                break
            }
            if (!0 !== a) if (a && e["throws"]) t = a(t);
            else try {
                t = a(t)
            } catch (f) {
                return {
                    state: "parsererror",
                    error: a ? f : "No conversion from " + u + " to " + o
                }
            }
        }
        return {
            state: "success",
            data: t
        }
    }
    function nn(e) {
        if (!C.contains(e.ownerDocument || g, e)) return !0;
        for (; e && 1 === e.nodeType;) {
            if ("none" === ((t = e).style && t.style.display || C.css(t, "display")) || "hidden" === e.type) return !0;
            e = e.parentNode
        }
        var t;
        return !1
    }
    C.extend({
        active: 0,
        lastModified: {},
        etag: {},
        ajaxSettings: {
            url: Kt,
            type: "GET",
            isLocal: /^(?:about|app|app-storage|.+-extension|file|res|widget):$/.test(_[1]),
            global: !0,
            processData: !0,
            "async": !0,
            contentType: "application/x-www-form-urlencoded; charset=UTF-8",
            accepts: {
                "*": Gt,
                text: "text/plain",
                html: "text/html",
                xml: "application/xml, text/xml",
                json: "application/json, text/javascript"
            },
            contents: {
                xml: /\bxml\b/,
                html: /\bhtml/,
                json: /\bjson\b/
            },
            responseFields: {
                xml: "responseXML",
                text: "responseText",
                json: "responseJSON"
            },
            converters: {
                "* text": String,
                "text html": !0,
                "text json": C.parseJSON,
                "text xml": C.parseXML
            },
            flatOptions: {
                url: !0,
                context: !0
            }
        },
        ajaxSetup: function(e, t) {
            return t ? en(en(e, C.ajaxSettings), t) : en(C.ajaxSettings, e)
        },
        ajaxPrefilter: Qt(Yt),
        ajaxTransport: Qt(Jt),
        ajax: function(e, t) {
            "object" == typeof e && (t = e, e = undefined);
            var n, u, l, c, f, d, r, p = C.ajaxSetup({}, t = t || {}),
                h = p.context || p,
                g = p.context && (h.nodeType || h.jquery) ? C(h) : C.event,
                m = C.Deferred(),
                y = C.Callbacks("once memory"),
                v = p.statusCode || {},
                i = {},
                o = {},
                x = 0,
                a = "canceled",
                b = {
                    readyState: 0,
                    getResponseHeader: function(e) {
                        var t;
                        if (2 === x) {
                            if (!r) for (r = {}; t = zt.exec(l);) r[t[1].toLowerCase()] = t[2];
                            t = r[e.toLowerCase()]
                        }
                        return null == t ? null : t
                    },
                    getAllResponseHeaders: function() {
                        return 2 === x ? l : null
                    },
                    setRequestHeader: function(e, t) {
                        var n = e.toLowerCase();
                        return x || (e = o[n] = o[n] || e, i[e] = t), this
                    },
                    overrideMimeType: function(e) {
                        return x || (p.mimeType = e), this
                    },
                    statusCode: function(e) {
                        if (e) if (x < 2) for (var t in e) v[t] = [v[t], e[t]];
                        else b.always(e[b.status]);
                        return this
                    },
                    abort: function(e) {
                        e = e || a;
                        return d && d.abort(e), s(0, e), this
                    }
                };
            if (m.promise(b).complete = y.add, b.success = b.done, b.error = b.fail, p.url = ((e || p.url || Kt) + "").replace(It, "").replace(Ut, _[1] + "//"), p.type = t.method || t.type || p.method || p.type, p.dataTypes = C.trim(p.dataType || "*").toLowerCase().match(E) || [""], null == p.crossDomain && (e = Vt.exec(p.url.toLowerCase()), p.crossDomain = !(!e || e[1] === _[1] && e[2] === _[2] && (e[3] || ("http:" === e[1] ? "80" : "443")) === (_[3] || ("http:" === _[1] ? "80" : "443")))), p.data && p.processData && "string" != typeof p.data && (p.data = C.param(p.data, p.traditional)), Zt(Yt, p, t, b), 2 === x) return b;
            for (n in (f = C.event && p.global) && 0 == C.active++ && C.event.trigger("ajaxStart"), p.type = p.type.toUpperCase(), p.hasContent = !Xt.test(p.type), u = p.url, p.hasContent || (p.data && (u = p.url += (Bt.test(u) ? "&" : "?") + p.data, delete p.data), !1 === p.cache && (p.url = $t.test(u) ? u.replace($t, "$1_=" + Pt++) : u + (Bt.test(u) ? "&" : "?") + "_=" + Pt++)), p.ifModified && (C.lastModified[u] && b.setRequestHeader("If-Modified-Since", C.lastModified[u]), C.etag[u] && b.setRequestHeader("If-None-Match", C.etag[u])), (p.data && p.hasContent && !1 !== p.contentType || t.contentType) && b.setRequestHeader("Content-Type", p.contentType), b.setRequestHeader("Accept", p.dataTypes[0] && p.accepts[p.dataTypes[0]] ? p.accepts[p.dataTypes[0]] + ("*" !== p.dataTypes[0] ? ", " + Gt + "; q=0.01" : "") : p.accepts["*"]), p.headers) b.setRequestHeader(n, p.headers[n]);
            if (p.beforeSend && (!1 === p.beforeSend.call(h, b, p) || 2 === x)) return b.abort();
            for (n in a = "abort", {
                success: 1,
                error: 1,
                complete: 1
            }) b[n](p[n]);
            if (d = Zt(Jt, p, t, b)) {
                if (b.readyState = 1, f && g.trigger("ajaxSend", [b, p]), 2 === x) return b;
                p["async"] && 0 < p.timeout && (c = T.setTimeout(function() {
                    b.abort("timeout")
                }, p.timeout));
                try {
                    x = 1, d.send(i, s)
                } catch (w) {
                    if (!(x < 2)) throw w;
                    s(-1, w)
                }
            } else s(-1, "No Transport");

            function s(e, t, n, r) {
                var i, o, a, s = t;
                2 !== x && (x = 2, c && T.clearTimeout(c), d = undefined, l = r || "", b.readyState = 0 < e ? 4 : 0, r = 200 <= e && e < 300 || 304 === e, n && (a = function(e, t, n) {
                    for (var r, i, o, a, s = e.contents, u = e.dataTypes;
                    "*" === u[0];) u.shift(), i === undefined && (i = e.mimeType || t.getResponseHeader("Content-Type"));
                    if (i) for (a in s) if (s[a] && s[a].test(i)) {
                        u.unshift(a);
                        break
                    }
                    if (u[0] in n) o = u[0];
                    else {
                        for (a in n) {
                            if (!u[0] || e.converters[a + " " + u[0]]) {
                                o = a;
                                break
                            }
                            r = r || a
                        }
                        o = o || r
                    }
                    if (o) return o !== u[0] && u.unshift(o), n[o]
                }(p, b, n)), a = tn(p, a, b, r), r ? (p.ifModified && ((n = b.getResponseHeader("Last-Modified")) && (C.lastModified[u] = n), (n = b.getResponseHeader("etag")) && (C.etag[u] = n)), 204 === e || "HEAD" === p.type ? s = "nocontent" : 304 === e ? s = "notmodified" : (s = a.state, i = a.data, r = !(o = a.error))) : (o = s, !e && s || (s = "error", e < 0 && (e = 0))), b.status = e, b.statusText = (t || s) + "", r ? m.resolveWith(h, [i, s, b]) : m.rejectWith(h, [b, s, o]), b.statusCode(v), v = undefined, f && g.trigger(r ? "ajaxSuccess" : "ajaxError", [b, p, r ? i : o]), y.fireWith(h, [b, s]), f && (g.trigger("ajaxComplete", [b, p]), --C.active || C.event.trigger("ajaxStop")))
            }
            return b
        },
        getJSON: function(e, t, n) {
            return C.get(e, t, n, "json")
        },
        getScript: function(e, t) {
            return C.get(e, undefined, t, "script")
        }
    }), C.each(["get", "post"], function(e, i) {
        C[i] = function(e, t, n, r) {
            return C.isFunction(t) && (r = r || n, n = t, t = undefined), C.ajax(C.extend({
                url: e,
                type: i,
                dataType: r,
                data: t,
                success: n
            }, C.isPlainObject(e) && e))
        }
    }), C._evalUrl = function(e) {
        return C.ajax({
            url: e,
            type: "GET",
            dataType: "script",
            cache: !0,
            "async": !1,
            global: !1,
            "throws": !0
        })
    }, C.fn.extend({
        wrapAll: function(t) {
            return C.isFunction(t) ? this.each(function(e) {
                C(this).wrapAll(t.call(this, e))
            }) : (this[0] && (e = C(t, this[0].ownerDocument).eq(0).clone(!0), this[0].parentNode && e.insertBefore(this[0]), e.map(function() {
                for (var e = this; e.firstChild && 1 === e.firstChild.nodeType;) e = e.firstChild;
                return e
            }).append(this)), this);
            var e
        },
        wrapInner: function(n) {
            return C.isFunction(n) ? this.each(function(e) {
                C(this).wrapInner(n.call(this, e))
            }) : this.each(function() {
                var e = C(this),
                    t = e.contents();
                t.length ? t.wrapAll(n) : e.append(n)
            })
        },
        wrap: function(t) {
            var n = C.isFunction(t);
            return this.each(function(e) {
                C(this).wrapAll(n ? t.call(this, e) : t)
            })
        },
        unwrap: function() {
            return this.parent().each(function() {
                C.nodeName(this, "body") || C(this).replaceWith(this.childNodes)
            }).end()
        }
    }), C.expr.filters.hidden = function(e) {
        return y.reliableHiddenOffsets() ? e.offsetWidth <= 0 && e.offsetHeight <= 0 && !e.getClientRects().length : nn(e)
    }, C.expr.filters.visible = function(e) {
        return !C.expr.filters.hidden(e)
    };
    var rn = /%20/g,
        on = /\[\]$/,
        an = /\r?\n/g,
        sn = /^(?:submit|button|image|reset|file)$/i,
        un = /^(?:input|select|textarea|keygen)/i;
    C.param = function(e, t) {
        var n, r = [],
            i = function(e, t) {
                t = C.isFunction(t) ? t() : null == t ? "" : t, r[r.length] = encodeURIComponent(e) + "=" + encodeURIComponent(t)
            };
        if (t === undefined && (t = C.ajaxSettings && C.ajaxSettings.traditional), C.isArray(e) || e.jquery && !C.isPlainObject(e)) C.each(e, function() {
            i(this.name, this.value)
        });
        else for (n in e)!
        function o(n, e, r, i) {
            if (C.isArray(e)) C.each(e, function(e, t) {
                r || on.test(n) ? i(n, t) : o(n + "[" + ("object" == typeof t && null != t ? e : "") + "]", t, r, i)
            });
            else if (r || "object" !== C.type(e)) i(n, e);
            else for (var t in e) o(n + "[" + t + "]", e[t], r, i)
        }(n, e[n], t, i);
        return r.join("&").replace(rn, "+")
    }, C.fn.extend({
        serialize: function() {
            return C.param(this.serializeArray())
        },
        serializeArray: function() {
            return this.map(function() {
                var e = C.prop(this, "elements");
                return e ? C.makeArray(e) : this
            }).filter(function() {
                var e = this.type;
                return this.name && !C(this).is(":disabled") && un.test(this.nodeName) && !sn.test(e) && (this.checked || !ge.test(e))
            }).map(function(e, t) {
                var n = C(this).val();
                return null == n ? null : C.isArray(n) ? C.map(n, function(e) {
                    return {
                        name: t.name,
                        value: e.replace(an, "\r\n")
                    }
                }) : {
                    name: t.name,
                    value: n.replace(an, "\r\n")
                }
            }).get()
        }
    }), C.ajaxSettings.xhr = T.ActiveXObject !== undefined ?
    function() {
        return this.isLocal ? dn() : 8 < g.documentMode ? fn() : /^(get|post|head|put|delete|options)$/i.test(this.type) && fn() || dn()
    } : fn;
    var ln = 0,
        cn = {},
        F = C.ajaxSettings.xhr();

    function fn() {
        try {
            return new T.XMLHttpRequest
        } catch (e) {}
    }
    function dn() {
        try {
            return new T.ActiveXObject("Microsoft.XMLHTTP")
        } catch (e) {}
    }
    T.attachEvent && T.attachEvent("onunload", function() {
        for (var e in cn) cn[e](undefined, !0)
    }), y.cors = !! F && "withCredentials" in F, (F = y.ajax = !! F) && C.ajaxTransport(function(l) {
        var c;
        if (!l.crossDomain || y.cors) return {
            send: function(e, a) {
                var t, s = l.xhr(),
                    u = ++ln;
                if (s.open(l.type, l.url, l["async"], l.username, l.password), l.xhrFields) for (t in l.xhrFields) s[t] = l.xhrFields[t];
                for (t in l.mimeType && s.overrideMimeType && s.overrideMimeType(l.mimeType), l.crossDomain || e["X-Requested-With"] || (e["X-Requested-With"] = "XMLHttpRequest"), e) e[t] !== undefined && s.setRequestHeader(t, e[t] + "");
                s.send(l.hasContent && l.data || null), c = function(e, t) {
                    var n, r, i;
                    if (c && (t || 4 === s.readyState)) if (delete cn[u], c = undefined, s.onreadystatechange = C.noop, t) 4 !== s.readyState && s.abort();
                    else {
                        i = {}, n = s.status, "string" == typeof s.responseText && (i.text = s.responseText);
                        try {
                            r = s.statusText
                        } catch (o) {
                            r = ""
                        }
                        n || !l.isLocal || l.crossDomain ? 1223 === n && (n = 204) : n = i.text ? 200 : 404
                    }
                    i && a(n, r, i, s.getAllResponseHeaders())
                }, l["async"] ? 4 === s.readyState ? T.setTimeout(c) : s.onreadystatechange = cn[u] = c : c()
            },
            abort: function() {
                c && c(undefined, !0)
            }
        }
    }), C.ajaxSetup({
        accepts: {
            script: "text/javascript, application/javascript, application/ecmascript, application/x-ecmascript"
        },
        contents: {
            script: /\b(?:java|ecma)script\b/
        },
        converters: {
            "text script": function(e) {
                return C.globalEval(e), e
            }
        }
    }), C.ajaxPrefilter("script", function(e) {
        e.cache === undefined && (e.cache = !1), e.crossDomain && (e.type = "GET", e.global = !1)
    }), C.ajaxTransport("script", function(t) {
        var r, i;
        if (t.crossDomain) return i = g.head || C("head")[0] || g.documentElement, {
            send: function(e, n) {
                (r = g.createElement("script"))["async"] = !0, t.scriptCharset && (r.charset = t.scriptCharset), r.src = t.url, r.onload = r.onreadystatechange = function(e, t) {
                    !t && r.readyState && !/loaded|complete/.test(r.readyState) || (r.onload = r.onreadystatechange = null, r.parentNode && r.parentNode.removeChild(r), r = null, t || n(200, "success"))
                }, i.insertBefore(r, i.firstChild)
            },
            abort: function() {
                r && r.onload(undefined, !0)
            }
        }
    });
    var pn = [],
        hn = /(=)\?(?=&|$)|\?\?/,
        gn = (C.ajaxSetup({
            jsonp: "callback",
            jsonpCallback: function() {
                var e = pn.pop() || C.expando + "_" + Pt++;
                return this[e] = !0, e
            }
        }), C.ajaxPrefilter("json jsonp", function(e, t, n) {
            var r, i, o, a = !1 !== e.jsonp && (hn.test(e.url) ? "url" : "string" == typeof e.data && 0 === (e.contentType || "").indexOf("application/x-www-form-urlencoded") && hn.test(e.data) && "data");
            if (a || "jsonp" === e.dataTypes[0]) return r = e.jsonpCallback = C.isFunction(e.jsonpCallback) ? e.jsonpCallback() : e.jsonpCallback, a ? e[a] = e[a].replace(hn, "$1" + r) : !1 !== e.jsonp && (e.url += (Bt.test(e.url) ? "&" : "?") + e.jsonp + "=" + r), e.converters["script json"] = function() {
                return o || C.error(r + " was not called"), o[0]
            }, e.dataTypes[0] = "json", i = T[r], T[r] = function() {
                o = arguments
            }, n.always(function() {
                i === undefined ? C(T).removeProp(r) : T[r] = i, e[r] && (e.jsonpCallback = t.jsonpCallback, pn.push(r)), o && C.isFunction(i) && i(o[0]), o = i = undefined
            }), "script"
        }), C.parseHTML = function(e, t, n) {
            if (!e || "string" != typeof e) return null;
            "boolean" == typeof t && (n = t, t = !1), t = t || g;
            var r = J.exec(e),
                n = !n && [];
            return r ? [t.createElement(r[1])] : (r = Ne([e], t, n), n && n.length && C(n).remove(), C.merge([], r.childNodes))
        }, C.fn.load);

    function mn(e) {
        return C.isWindow(e) ? e : 9 === e.nodeType && (e.defaultView || e.parentWindow)
    }
    return C.fn.load = function(e, t, n) {
        if ("string" != typeof e && gn) return gn.apply(this, arguments);
        var r, i, o, a = this,
            s = e.indexOf(" ");
        return -1 < s && (r = C.trim(e.slice(s, e.length)), e = e.slice(0, s)), C.isFunction(t) ? (n = t, t = undefined) : t && "object" == typeof t && (i = "POST"), 0 < a.length && C.ajax({
            url: e,
            type: i || "GET",
            dataType: "html",
            data: t
        }).done(function(e) {
            o = arguments, a.html(r ? C("<div>").append(C.parseHTML(e)).find(r) : e)
        }).always(n &&
        function(e, t) {
            a.each(function() {
                n.apply(this, o || [e.responseText, t, e])
            })
        }), this
    }, C.each(["ajaxStart", "ajaxStop", "ajaxComplete", "ajaxError", "ajaxSuccess", "ajaxSend"], function(e, t) {
        C.fn[t] = function(e) {
            return this.on(t, e)
        }
    }), C.expr.filters.animated = function(t) {
        return C.grep(C.timers, function(e) {
            return t === e.elem
        }).length
    }, C.offset = {
        setOffset: function(e, t, n) {
            var r, i, o, a, s = C.css(e, "position"),
                u = C(e),
                l = {};
            "static" === s && (e.style.position = "relative"), o = u.offset(), r = C.css(e, "top"), a = C.css(e, "left"), s = ("absolute" === s || "fixed" === s) && -1 < C.inArray("auto", [r, a]) ? (i = (s = u.position()).top, s.left) : (i = parseFloat(r) || 0, parseFloat(a) || 0), null != (t = C.isFunction(t) ? t.call(e, n, C.extend({}, o)) : t).top && (l.top = t.top - o.top + i), null != t.left && (l.left = t.left - o.left + s), "using" in t ? t.using.call(e, l) : u.css(l)
        }
    }, C.fn.extend({
        offset: function(t) {
            if (arguments.length) return t === undefined ? this : this.each(function(e) {
                C.offset.setOffset(this, t, e)
            });
            var e, n = {
                top: 0,
                left: 0
            },
                r = this[0],
                i = r && r.ownerDocument;
            return i ? (e = i.documentElement, C.contains(e, r) ? ("undefined" != typeof r.getBoundingClientRect && (n = r.getBoundingClientRect()), r = mn(i), {
                top: n.top + (r.pageYOffset || e.scrollTop) - (e.clientTop || 0),
                left: n.left + (r.pageXOffset || e.scrollLeft) - (e.clientLeft || 0)
            }) : n) : void 0
        },
        position: function() {
            var e, t, n, r;
            if (this[0]) return n = {
                top: 0,
                left: 0
            }, r = this[0], "fixed" === C.css(r, "position") ? t = r.getBoundingClientRect() : (e = this.offsetParent(), t = this.offset(), (n = C.nodeName(e[0], "html") ? n : e.offset()).top += C.css(e[0], "borderTopWidth", !0), n.left += C.css(e[0], "borderLeftWidth", !0)), {
                top: t.top - n.top - C.css(r, "marginTop", !0),
                left: t.left - n.left - C.css(r, "marginLeft", !0)
            }
        },
        offsetParent: function() {
            return this.map(function() {
                for (var e = this.offsetParent; e && !C.nodeName(e, "html") && "static" === C.css(e, "position");) e = e.offsetParent;
                return e || lt
            })
        }
    }), C.each({
        scrollLeft: "pageXOffset",
        scrollTop: "pageYOffset"
    }, function(t, i) {
        var o = /Y/.test(i);
        C.fn[t] = function(e) {
            return d(this, function(e, t, n) {
                var r = mn(e);
                if (n === undefined) return r ? i in r ? r[i] : r.document.documentElement[t] : e[t];
                r ? r.scrollTo(o ? C(r).scrollLeft() : n, o ? n : C(r).scrollTop()) : e[t] = n
            }, t, e, arguments.length, null)
        }
    }), C.each(["top", "left"], function(e, n) {
        C.cssHooks[n] = ft(y.pixelPosition, function(e, t) {
            if (t) return t = p(e, n), st.test(t) ? C(e).position()[n] + "px" : t
        })
    }), C.each({
        Height: "height",
        Width: "width"
    }, function(o, a) {
        C.each({
            padding: "inner" + o,
            content: a,
            "": "outer" + o
        }, function(r, e) {
            C.fn[e] = function(e, t) {
                var n = arguments.length && (r || "boolean" != typeof e),
                    i = r || (!0 === e || !0 === t ? "margin" : "border");
                return d(this, function(e, t, n) {
                    var r;
                    return C.isWindow(e) ? e.document.documentElement["client" + o] : 9 === e.nodeType ? (r = e.documentElement, Math.max(e.body["scroll" + o], r["scroll" + o], e.body["offset" + o], r["offset" + o], r["client" + o])) : n === undefined ? C.css(e, t, i) : C.style(e, t, n, i)
                }, a, n ? e : undefined, n, null)
            }
        })
    }), C.fn.extend({
        bind: function(e, t, n) {
            return this.on(e, null, t, n)
        },
        unbind: function(e, t) {
            return this.off(e, null, t)
        },
        delegate: function(e, t, n, r) {
            return this.on(t, e, n, r)
        },
        undelegate: function(e, t, n) {
            return 1 === arguments.length ? this.off(e, "**") : this.off(t, e || "**", n)
        }
    }), C.fn.size = function() {
        return this.length
    }, C.fn.andSelf = C.fn.addBack, layui.define(function(e) {
        e("jquery", layui.$ = C)
    }), C
});
layui.define(function(e) {
    "use strict";
    var p = {
        open: "{{",
        close: "}}"
    },
        a = {
            exp: function(e) {
                return new RegExp(e, "g")
            },
            query: function(e, r, n) {
                return l((r || "") + p.open + ["#([\\s\\S])+?", "([^{#}])*?"][e || 0] + p.close + (n || ""))
            },
            escape: function(e) {
                return e === undefined || null === e ? "" : /[<"'>]|&(?=#[a-zA-Z0-9]+)/g.test(e += "") ? e.replace(/&(?!#?[a-zA-Z0-9]+;)/g, "&amp;").replace(/</g, "&lt;").replace(/>/g, "&gt;").replace(/'/g, "&#39;").replace(/"/g, "&quot;") : e
            },
            error: function(e, r) {
                var n = "Laytpl Error: ";
                return "object" == typeof console && console.error(n + e + "\n" + (r || "")), n + e
            }
        },
        l = a.exp,
        r = function(e) {
            this.tpl = e
        },
        n = (r.pt = r.prototype, window.errors = 0, r.pt.parse = function(e, r) {
            var n = e,
                c = l("^" + p.open + "#", ""),
                t = l(p.close + "$", "");
            e = '"use strict";var view = "' + (e = e.replace(/\s+|\r|\t|\n/g, " ").replace(l(p.open + "#"), p.open + "# ").replace(l(p.close + "}"), "} " + p.close).replace(/\\/g, "\\\\").replace(l(p.open + "!(.+?)!" + p.close), function(e) {
                return e = e.replace(l("^" + p.open + "!"), "").replace(l("!" + p.close), "").replace(l(p.open + "|" + p.close), function(e) {
                    return e.replace(/(.)/g, "\\$1")
                })
            }).replace(/(?="|')/g, "\\").replace(a.query(), function(e) {
                return '";' + (e = e.replace(c, "").replace(t, "")).replace(/\\(.)/g, "$1") + ';view+="'
            }).replace(a.query(1), function(e) {
                var r = '"+laytpl.escape(';
                return e.replace(/\s/g, "") === p.open + p.close ? "" : (e = e.replace(l(p.open + "|" + p.close), ""), /^=/.test(e) ? e = e.replace(/^=/, "") : /^-/.test(e) && (e = e.replace(/^-/, ""), r = '"+('), r + e.replace(/\\(.)/g, "$1") + ')+"')
            })) + '";return view;';
            try {
                return this.cache = e = new Function("d, laytpl", e), e(r, a)
            } catch (o) {
                return delete this.cache, a.error(o, n)
            }
        }, r.pt.render = function(e, r) {
            var n = this;
            return e ? (e = n.cache ? n.cache(e, a) : n.parse(n.tpl, e), r ? void r(e) : e) : a.error("no data")
        }, function(e) {
            return "string" != typeof e ? a.error("Template not found") : new r(e)
        });
    n.config = function(e) {
        for (var r in e = e || {}) p[r] = e[r]
    }, n.v = "1.2.0", e("laytpl", n)
});
!
function(p) {
    "use strict";
    var h, c, e, n = p.layui && layui.define,
        f = {
            getPath: (e = document.currentScript ? document.currentScript.src : function() {
                for (var e, t = document.scripts, i = t.length - 1, n = i; 0 < n; n--) if ("interactive" === t[n].readyState) {
                    e = t[n].src;
                    break
                }
                return e || t[i].src
            }(), (p.LAYUI_GLOBAL || {}).layer_dir || e.substring(0, e.lastIndexOf("/") + 1)),
            config: {},
            end: {},
            events: {
                resize: {}
            },
            minIndex: 0,
            minLeft: [],
            btn: ["&#x786E;&#x5B9A;", "&#x53D6;&#x6D88;"],
            type: ["dialog", "page", "iframe", "loading", "tips"],
            getStyle: function(e, t) {
                e = e.currentStyle || p.getComputedStyle(e, null);
                return e[e.getPropertyValue ? "getPropertyValue" : "getAttribute"](t)
            },
            link: function(e, i, t) {
                var n, a, o, s, l, r;
                m.path && (n = document.getElementsByTagName("head")[0], a = document.createElement("link"), o = ((t = "string" == typeof i ? i : t) || e).replace(/\.|\//g, ""), s = "layuicss-" + o, l = "creating", r = 0, a.rel = "stylesheet", a.href = m.path + e, a.id = s, document.getElementById(s) || n.appendChild(a), "function" == typeof i &&
                function c(e) {
                    var t = document.getElementById(s);
                    return 100 < ++r ? p.console && console.error(o + ".css: Invalid") : void(1989 === parseInt(f.getStyle(t, "width")) ? (e === l && t.removeAttribute("lay-status"), t.getAttribute("lay-status") === l ? setTimeout(c, 100) : i()) : (t.setAttribute("lay-status", l), setTimeout(function() {
                        c(l)
                    }, 100)))
                }())
            }
        },
        m = {
            v: "3.6.0",
            ie: (e = navigator.userAgent.toLowerCase(), !! (p.ActiveXObject || "ActiveXObject" in p) && ((e.match(/msie\s(\d+)/) || [])[1] || "11")),
            index: p.layer && p.layer.v ? 1e5 : 0,
            path: f.getPath,
            config: function(e, t) {
                return m.cache = f.config = h.extend({}, f.config, e = e || {}), m.path = f.config.path || m.path, "string" == typeof e.extend && (e.extend = [e.extend]), f.config.path && m.ready(), e.extend && (n ? layui.addcss("modules/layer/" + e.extend) : f.link("css/" + e.extend)), this
            },
            ready: function(e) {
                var t = "layer",
                    i = (n ? "modules/" : "css/") + "layer.css?v=" + m.v;
                return n ? layui["layui.all"] ? "function" == typeof e && e() : layui.addcss(i, e, t) : f.link(i, e, t), this
            },
            alert: function(e, t, i) {
                var n = "function" == typeof t;
                return m.open(h.extend({
                    content: e,
                    yes: i = n ? t : i
                }, n ? {} : t))
            },
            confirm: function(e, t, i, n) {
                var a = "function" == typeof t;
                return a && (n = i, i = t), m.open(h.extend({
                    content: e,
                    btn: f.btn,
                    yes: i,
                    btn2: n
                }, a ? {} : t))
            },
            msg: function(e, t, i) {
                var n = "function" == typeof t,
                    a = f.config.skin,
                    a = (a ? a + " " + a + "-msg" : "") || "layui-layer-msg",
                    o = d.anim.length - 1;
                return n && (i = t), m.open(h.extend({
                    content: e,
                    time: 3e3,
                    shade: !1,
                    skin: a,
                    title: !1,
                    closeBtn: !1,
                    btn: !1,
                    resize: !1,
                    end: i
                }, n && !f.config.skin ? {
                    skin: a + " layui-layer-hui",
                    anim: o
                } : (-1 !== (t = t || {}).icon && (void 0 !== t.icon || f.config.skin) || (t.skin = a + " " + (t.skin || "layui-layer-hui")), t)))
            },
            load: function(e, t) {
                return m.open(h.extend({
                    type: 3,
                    icon: e || 0,
                    resize: !1,
                    shade: .01
                }, t))
            },
            tips: function(e, t, i) {
                return m.open(h.extend({
                    type: 4,
                    content: [e, t],
                    closeBtn: !1,
                    time: 3e3,
                    shade: !1,
                    resize: !1,
                    fixed: !1,
                    maxWidth: 260
                }, i))
            }
        },
        t = function(e) {
            var t = this,
                i = function() {
                    t.creat()
                };
            t.index = ++m.index, t.config.maxWidth = h(c).width() - 30, t.config = h.extend({}, t.config, f.config, e), document.body ? i() : setTimeout(function() {
                i()
            }, 30)
        },
        d = (t.pt = t.prototype, ["layui-layer", ".layui-layer-title", ".layui-layer-main", ".layui-layer-dialog", "layui-layer-iframe", "layui-layer-content", "layui-layer-btn", "layui-layer-close"]),
        i = (d.anim = ["layer-anim-00", "layer-anim-01", "layer-anim-02", "layer-anim-03", "layer-anim-04", "layer-anim-05", "layer-anim-06"], d.SHADE = "layui-layer-shade", d.MOVE = "layui-layer-move", t.pt.config = {
            type: 0,
            shade: .3,
            fixed: !0,
            move: d[1],
            title: "&#x4FE1;&#x606F;",
            offset: "auto",
            area: "auto",
            closeBtn: 1,
            time: 0,
            zIndex: 19891014,
            maxWidth: 360,
            anim: 0,
            isOutAnim: !0,
            minStack: !0,
            icon: -1,
            moveType: 1,
            resize: !0,
            scrollbar: !0,
            tips: 2
        }, t.pt.vessel = function(e, t) {
            var i, n = this.index,
                a = this.config,
                o = a.zIndex + n,
                s = "object" == typeof a.title,
                l = a.maxmin && (1 === a.type || 2 === a.type),
                s = a.title ? '<div class="layui-layer-title" style="' + (s ? a.title[1] : "") + '">' + (s ? a.title[0] : a.title) + "</div>" : "";
            return a.zIndex = o, t([a.shade ? '<div class="' + d.SHADE + '" id="' + d.SHADE + n + '" times="' + n + '" style="z-index:' + (o - 1) + '; "></div>' : "", '<div class="' + d[0] + " layui-layer-" + f.type[a.type] + (0 != a.type && 2 != a.type || a.shade ? "" : " layui-layer-border") + " " + (a.skin || "") + '" id="' + d[0] + n + '" type="' + f.type[a.type] + '" times="' + n + '" showtime="' + a.time + '" conType="' + (e ? "object" : "string") + '" style="z-index: ' + o + "; width:" + a.area[0] + ";height:" + a.area[1] + ";position:" + (a.fixed ? "fixed;" : "absolute;") + '">' + (e && 2 != a.type ? "" : s) + "<div" + (a.id ? ' id="' + a.id + '"' : "") + ' class="layui-layer-content' + (0 == a.type && -1 !== a.icon ? " layui-layer-padding" : "") + (3 == a.type ? " layui-layer-loading" + a.icon : "") + '">' + (n = ["layui-icon-tips", "layui-icon-ok", "layui-icon-close-fill", "layui-icon-help", "layui-icon-password", "layui-icon-face-cry", "layui-icon-face-smile"], o = "layui-anim layui-anim-rotate layui-anim-loop", 0 == a.type && -1 !== a.icon ? '<i class="layui-layer-face layui-icon ' + ((i = 16 == a.icon ? "layui-icon layui-icon-loading " + o : i) || n[a.icon] || n[0]) + '"></i>' : 3 == a.type ? (i = ["layui-icon-loading", "layui-icon-loading-1"], 2 == a.icon ? '<div class="layui-layer-loading-2 ' + o + '"></div>' : '<i class="layui-layer-loading-icon layui-icon ' + (i[a.icon] || i[0]) + " " + o + '"></i>') : "") + ((1 != a.type || !e) && a.content || "") + '</div><div class="layui-layer-setwin">' + (n = [], l && (n.push('<span class="layui-layer-min"></span>'), n.push('<span class="layui-layer-max"></span>')), a.closeBtn && n.push('<span class="layui-icon layui-icon-close ' + [d[7], d[7] + (a.title ? a.closeBtn : 4 == a.type ? "1" : "2")].join(" ") + '"></span>'), n.join("")) + "</div>" + (a.btn ?
            function() {
                var e = "";
                "string" == typeof a.btn && (a.btn = [a.btn]);
                for (var t = 0, i = a.btn.length; t < i; t++) e += '<a class="' + d[6] + t + '">' + a.btn[t] + "</a>";
                return '<div class="' + d[6] + " layui-layer-btn-" + (a.btnAlign || "") + '">' + e + "</div>"
            }() : "") + (a.resize ? '<span class="layui-layer-resize"></span>' : "") + "</div>"], s, h('<div class="' + d.MOVE + '" id="' + d.MOVE + '"></div>')), this
        }, t.pt.creat = function() {
            var e, n = this,
                a = n.config,
                o = n.index,
                s = "object" == typeof(r = a.content),
                l = h("body");
            if (!a.id || !h("." + d[0]).find("#" + a.id)[0]) {
                switch ("string" == typeof a.area && (a.area = "auto" === a.area ? ["", ""] : [a.area, ""]), a.shift && (a.anim = a.shift), 6 == m.ie && (a.fixed = !1), a.type) {
                case 0:
                    a.btn = "btn" in a ? a.btn : f.btn[0], m.closeAll("dialog");
                    break;
                case 2:
                    var r = a.content = s ? a.content : [a.content || "", "auto"];
                    a.content = '<iframe scrolling="' + (a.content[1] || "auto") + '" allowtransparency="true" id="' + d[4] + o + '" name="' + d[4] + o + '" onload="this.className=\'\';" class="layui-layer-load" frameborder="0" src="' + a.content[0] + '"></iframe>';
                    break;
                case 3:
                    delete a.title, delete a.closeBtn, -1 === a.icon && a.icon, m.closeAll("loading");
                    break;
                case 4:
                    s || (a.content = [a.content, "body"]), a.follow = a.content[1], a.content = a.content[0] + '<i class="layui-layer-TipsG"></i>', delete a.title, a.tips = "object" == typeof a.tips ? a.tips : [a.tips, !0], a.tipsMore || m.closeAll("tips")
                }
                n.vessel(s, function(e, t, i) {
                    l.append(e[0]), s ? 2 == a.type || 4 == a.type ? h("body").append(e[1]) : r.parents("." + d[0])[0] || (r.data("display", r.css("display")).show().addClass("layui-layer-wrap").wrap(e[1]), h("#" + d[0] + o).find("." + d[5]).before(t)) : l.append(e[1]), h("#" + d.MOVE)[0] || l.append(f.moveElem = i), n.layero = h("#" + d[0] + o), n.shadeo = h("#" + d.SHADE + o), a.scrollbar || d.html.css("overflow", "hidden").attr("layer-full", o)
                }).auto(o), n.shadeo.css({
                    "background-color": a.shade[1] || "#000",
                    opacity: a.shade[0] || a.shade
                }), 2 == a.type && 6 == m.ie && n.layero.find("iframe").attr("src", r[0]), 4 == a.type ? n.tips() : (n.offset(), parseInt(f.getStyle(document.getElementById(d.MOVE), "z-index")) || (n.layero.css("visibility", "hidden"), m.ready(function() {
                    n.offset(), n.layero.css("visibility", "visible")
                }))), !a.fixed || f.events.resize[n.index] || (f.events.resize[n.index] = function() {
                    n.resize()
                }, c.on("resize", f.events.resize[n.index])), a.time <= 0 || setTimeout(function() {
                    m.close(n.index)
                }, a.time), n.move().callback(), d.anim[a.anim] && (e = "layer-anim " + d.anim[a.anim], n.layero.addClass(e).one("webkitAnimationEnd mozAnimationEnd MSAnimationEnd oanimationend animationend", function() {
                    h(this).removeClass(e)
                })), a.isOutAnim && n.layero.data("isOutAnim", !0)
            }
        }, t.pt.resize = function() {
            var e = this,
                t = e.config;
            e.offset(), (/^\d+%$/.test(t.area[0]) || /^\d+%$/.test(t.area[1])) && e.auto(e.index), 4 == t.type && e.tips()
        }, t.pt.auto = function(e) {
            var t = this.config,
                i = h("#" + d[0] + e),
                n = ("" === t.area[0] && 0 < t.maxWidth && (m.ie && m.ie < 8 && t.btn && i.width(i.innerWidth()), i.outerWidth() > t.maxWidth && i.width(t.maxWidth)), [i.innerWidth(), i.innerHeight()]),
                a = i.find(d[1]).outerHeight() || 0,
                o = i.find("." + d[6]).outerHeight() || 0,
                e = function(e) {
                    (e = i.find(e)).height(n[1] - a - o - 2 * (0 | parseFloat(e.css("padding-top"))))
                };
            return 2 === t.type ? e("iframe") : "" === t.area[1] ? 0 < t.maxHeight && i.outerHeight() > t.maxHeight ? (n[1] = t.maxHeight, e("." + d[5])) : t.fixed && n[1] >= c.height() && (n[1] = c.height(), e("." + d[5])) : e("." + d[5]), this
        }, t.pt.offset = function() {
            var e = this,
                t = e.config,
                i = e.layero,
                n = [i.outerWidth(), i.outerHeight()],
                a = "object" == typeof t.offset;
            e.offsetTop = (c.height() - n[1]) / 2, e.offsetLeft = (c.width() - n[0]) / 2, a ? (e.offsetTop = t.offset[0], e.offsetLeft = t.offset[1] || e.offsetLeft) : "auto" !== t.offset && ("t" === t.offset ? e.offsetTop = 0 : "r" === t.offset ? e.offsetLeft = c.width() - n[0] : "b" === t.offset ? e.offsetTop = c.height() - n[1] : "l" === t.offset ? e.offsetLeft = 0 : "lt" === t.offset ? (e.offsetTop = 0, e.offsetLeft = 0) : "lb" === t.offset ? (e.offsetTop = c.height() - n[1], e.offsetLeft = 0) : "rt" === t.offset ? (e.offsetTop = 0, e.offsetLeft = c.width() - n[0]) : "rb" === t.offset ? (e.offsetTop = c.height() - n[1], e.offsetLeft = c.width() - n[0]) : e.offsetTop = t.offset), t.fixed || (e.offsetTop = /%$/.test(e.offsetTop) ? c.height() * parseFloat(e.offsetTop) / 100 : parseFloat(e.offsetTop), e.offsetLeft = /%$/.test(e.offsetLeft) ? c.width() * parseFloat(e.offsetLeft) / 100 : parseFloat(e.offsetLeft), e.offsetTop += c.scrollTop(), e.offsetLeft += c.scrollLeft()), i.attr("minLeft") && (e.offsetTop = c.height() - (i.find(d[1]).outerHeight() || 0), e.offsetLeft = i.css("left")), i.css({
                top: e.offsetTop,
                left: e.offsetLeft
            })
        }, t.pt.tips = function() {
            var e = this.config,
                t = this.layero,
                i = [t.outerWidth(), t.outerHeight()],
                n = h(e.follow),
                a = {
                    width: (n = n[0] ? n : h("body")).outerWidth(),
                    height: n.outerHeight(),
                    top: n.offset().top,
                    left: n.offset().left
                },
                o = t.find(".layui-layer-TipsG"),
                n = e.tips[0];
            e.tips[1] || o.remove(), a.autoLeft = function() {
                0 < a.left + i[0] - c.width() ? (a.tipLeft = a.left + a.width - i[0], o.css({
                    right: 12,
                    left: "auto"
                })) : a.tipLeft = a.left
            }, a.where = [function() {
                a.autoLeft(), a.tipTop = a.top - i[1] - 10, o.removeClass("layui-layer-TipsB").addClass("layui-layer-TipsT").css("border-right-color", e.tips[1])
            }, function() {
                a.tipLeft = a.left + a.width + 10, a.tipTop = a.top, o.removeClass("layui-layer-TipsL").addClass("layui-layer-TipsR").css("border-bottom-color", e.tips[1])
            }, function() {
                a.autoLeft(), a.tipTop = a.top + a.height + 10, o.removeClass("layui-layer-TipsT").addClass("layui-layer-TipsB").css("border-right-color", e.tips[1])
            }, function() {
                a.tipLeft = a.left - i[0] - 10, a.tipTop = a.top, o.removeClass("layui-layer-TipsR").addClass("layui-layer-TipsL").css("border-bottom-color", e.tips[1])
            }], a.where[n - 1](), 1 === n ? a.top - (c.scrollTop() + i[1] + 16) < 0 && a.where[2]() : 2 === n ? 0 < c.width() - (a.left + a.width + i[0] + 16) || a.where[3]() : 3 === n ? 0 < a.top - c.scrollTop() + a.height + i[1] + 16 - c.height() && a.where[0]() : 4 === n && 0 < i[0] + 16 - a.left && a.where[1](), t.find("." + d[5]).css({
                "background-color": e.tips[1],
                "padding-right": e.closeBtn ? "30px" : ""
            }), t.css({
                left: a.tipLeft - (e.fixed ? c.scrollLeft() : 0),
                top: a.tipTop - (e.fixed ? c.scrollTop() : 0)
            })
        }, t.pt.move = function() {
            var n = this,
                a = n.config,
                e = h(document),
                o = n.layero,
                r = ["LAY_MOVE_DICT", "LAY_RESIZE_DICT"],
                t = o.find(a.move),
                i = o.find(".layui-layer-resize");
            return a.move && t.css("cursor", "move"), t.on("mousedown", function(e) {
                var t = h(this),
                    i = {};
                a.move && (i.layero = o, i.config = a, i.offset = [e.clientX - parseFloat(o.css("left")), e.clientY - parseFloat(o.css("top"))], t.data(r[0], i), f.eventMoveElem = t, f.moveElem.css("cursor", "move").show()), e.preventDefault()
            }), i.on("mousedown", function(e) {
                var t = h(this),
                    i = {};
                a.resize && (i.layero = o, i.config = a, i.offset = [e.clientX, e.clientY], i.index = n.index, i.area = [o.outerWidth(), o.outerHeight()], t.data(r[1], i), f.eventResizeElem = t, f.moveElem.css("cursor", "se-resize").show()), e.preventDefault()
            }), f.docEvent || (e.on("mousemove", function(e) {
                var t, i, n, a, o, s, l;
                f.eventMoveElem && (t = (a = f.eventMoveElem.data(r[0]) || {}).layero, o = a.config, s = e.clientX - a.offset[0], l = e.clientY - a.offset[1], i = "fixed" === t.css("position"), e.preventDefault(), a.stX = i ? 0 : c.scrollLeft(), a.stY = i ? 0 : c.scrollTop(), o.moveOut || (i = c.width() - t.outerWidth() + a.stX, n = c.height() - t.outerHeight() + a.stY, i < (s = s < a.stX ? a.stX : s) && (s = i), n < (l = l < a.stY ? a.stY : l) && (l = n)), t.css({
                    left: s,
                    top: l
                })), f.eventResizeElem && (o = (a = f.eventResizeElem.data(r[1]) || {}).config, s = e.clientX - a.offset[0], l = e.clientY - a.offset[1], e.preventDefault(), m.style(a.index, {
                    width: a.area[0] + s,
                    height: a.area[1] + l
                }), o.resizing && o.resizing(a.layero))
            }).on("mouseup", function(e) {
                var t, i;
                f.eventMoveElem && (i = (t = f.eventMoveElem.data(r[0]) || {}).config, f.eventMoveElem.removeData(r[0]), delete f.eventMoveElem, f.moveElem.hide(), i.moveEnd && i.moveEnd(t.layero)), f.eventResizeElem && (f.eventResizeElem.removeData(r[1]), delete f.eventResizeElem, f.moveElem.hide())
            }), f.docEvent = !0), n
        }, t.pt.callback = function() {
            var t = this,
                i = t.layero,
                n = t.config;
            t.openLayer(), n.success && (2 == n.type ? i.find("iframe").on("load", function() {
                n.success(i, t.index, t)
            }) : n.success(i, t.index, t)), 6 == m.ie && t.IE6(i), i.find("." + d[6]).children("a").on("click", function() {
                var e = h(this).index();
                0 === e ? n.yes ? n.yes(t.index, i, t) : n.btn1 ? n.btn1(t.index, i, t) : m.close(t.index) : !1 !== (n["btn" + (e + 1)] && n["btn" + (e + 1)](t.index, i, t)) && m.close(t.index)
            }), i.find("." + d[7]).on("click", function() {
                !1 !== (n.cancel && n.cancel(t.index, i, t)) && m.close(t.index)
            }), n.shadeClose && t.shadeo.on("click", function() {
                m.close(t.index)
            }), i.find(".layui-layer-min").on("click", function() {
                !1 !== (n.min && n.min(i, t.index, t)) && m.min(t.index, n)
            }), i.find(".layui-layer-max").on("click", function() {
                h(this).hasClass("layui-layer-maxmin") ? (m.restore(t.index), n.restore && n.restore(i, t.index, t)) : (m.full(t.index, n), setTimeout(function() {
                    n.full && n.full(i, t.index, t)
                }, 100))
            }), n.end && (f.end[t.index] = n.end)
        }, f.reselect = function() {
            h.each(h("select"), function(e, t) {
                var i = h(this);
                i.parents("." + d[0])[0] || 1 == i.attr("layer") && h("." + d[0]).length < 1 && i.removeAttr("layer").show()
            })
        }, t.pt.IE6 = function(e) {
            h("select").each(function(e, t) {
                var i = h(this);
                i.parents("." + d[0])[0] || "none" !== i.css("display") && i.attr({
                    layer: "1"
                }).hide()
            })
        }, t.pt.openLayer = function() {
            m.zIndex = this.config.zIndex, m.setTop = function(e) {
                return m.zIndex = parseInt(e[0].style.zIndex), e.on("mousedown", function() {
                    m.zIndex++, e.css("z-index", m.zIndex + 1)
                }), m.zIndex
            }
        }, f.record = function(e) {
            var t = [e.width(), e.height(), e.position().top, e.position().left + parseFloat(e.css("margin-left"))];
            e.find(".layui-layer-max").addClass("layui-layer-maxmin"), e.attr({
                area: t
            })
        }, f.rescollbar = function(e) {
            d.html.attr("layer-full") == e && (d.html[0].style.removeProperty ? d.html[0].style.removeProperty("overflow") : d.html[0].style.removeAttribute("overflow"), d.html.removeAttr("layer-full"))
        }, (p.layer = m).getChildFrame = function(e, t) {
            return t = t || h("." + d[4]).attr("times"), h("#" + d[0] + t).find("iframe").contents().find(e)
        }, m.getFrameIndex = function(e) {
            return h("#" + e).parents("." + d[4]).attr("times")
        }, m.iframeAuto = function(e) {
            var t, i, n;
            e && (t = m.getChildFrame("html", e).outerHeight(), i = (e = h("#" + d[0] + e)).find(d[1]).outerHeight() || 0, n = e.find("." + d[6]).outerHeight() || 0, e.css({
                height: t + i + n
            }), e.find("iframe").css({
                height: t
            }))
        }, m.iframeSrc = function(e, t) {
            h("#" + d[0] + e).find("iframe").attr("src", t)
        }, m.style = function(e, t, i) {
            var e = h("#" + d[0] + e),
                n = e.find(".layui-layer-content"),
                a = e.attr("type"),
                o = e.find(d[1]).outerHeight() || 0,
                s = e.find("." + d[6]).outerHeight() || 0;
            e.attr("minLeft");
            a !== f.type[3] && a !== f.type[4] && (i || (parseFloat(t.width) <= 260 && (t.width = 260), parseFloat(t.height) - o - s <= 64 && (t.height = 64 + o + s)), e.css(t), s = e.find("." + d[6]).outerHeight() || 0, a === f.type[2] ? e.find("iframe").css({
                height: parseFloat(t.height) - o - s
            }) : n.css({
                height: parseFloat(t.height) - o - s - parseFloat(n.css("padding-top")) - parseFloat(n.css("padding-bottom"))
            }))
        }, m.min = function(e, t) {
            t = t || {};
            var i = h("#" + d[0] + e),
                n = h("#" + d.SHADE + e),
                a = i.find(d[1]).outerHeight() || 0,
                o = i.attr("minLeft") || 181 * f.minIndex + "px",
                s = i.css("position"),
                l = {
                    width: 180,
                    height: a,
                    position: "fixed",
                    overflow: "hidden"
                };
            f.record(i), f.minLeft[0] && (o = f.minLeft[0], f.minLeft.shift()), t.minStack && (l.left = o, l.top = c.height() - a, i.attr("minLeft") || f.minIndex++, i.attr("minLeft", o)), i.attr("position", s), m.style(e, l, !0), i.find(".layui-layer-min").hide(), "page" === i.attr("type") && i.find(d[4]).hide(), f.rescollbar(e), n.hide()
        }, m.restore = function(e) {
            var t = h("#" + d[0] + e),
                i = h("#" + d.SHADE + e),
                n = t.attr("area").split(",");
            t.attr("type");
            m.style(e, {
                width: parseFloat(n[0]),
                height: parseFloat(n[1]),
                top: parseFloat(n[2]),
                left: parseFloat(n[3]),
                position: t.attr("position"),
                overflow: "visible"
            }, !0), t.find(".layui-layer-max").removeClass("layui-layer-maxmin"), t.find(".layui-layer-min").show(), "page" === t.attr("type") && t.find(d[4]).show(), f.rescollbar(e), i.show()
        }, m.full = function(t) {
            var i = h("#" + d[0] + t);
            f.record(i), d.html.attr("layer-full") || d.html.css("overflow", "hidden").attr("layer-full", t), clearTimeout(void 0), setTimeout(function() {
                var e = "fixed" === i.css("position");
                m.style(t, {
                    top: e ? 0 : c.scrollTop(),
                    left: e ? 0 : c.scrollLeft(),
                    width: c.width(),
                    height: c.height()
                }, !0), i.find(".layui-layer-min").hide()
            }, 100)
        }, m.title = function(e, t) {
            h("#" + d[0] + (t || m.index)).find(d[1]).html(e)
        }, m.close = function(a, o) {
            var e, s, t, l = (e = h("." + d[0]).find("#" + a).closest("." + d[0]))[0] ? (a = e.attr("times"), e) : h("#" + d[0] + a),
                r = l.attr("type");
            l[0] && (s = "layui-layer-wrap", t = function() {
                if (r === f.type[1] && "object" === l.attr("conType")) {
                    l.children(":not(." + d[5] + ")").remove();
                    for (var e = l.find("." + s), t = 0; t < 2; t++) e.unwrap();
                    e.css("display", e.data("display")).removeClass(s)
                } else {
                    if (r === f.type[2]) try {
                        var i = h("#" + d[4] + a)[0];
                        i.contentWindow.document.write(""), i.contentWindow.close(), l.find("." + d[5])[0].removeChild(i)
                    } catch (n) {}
                    l[0].innerHTML = "", l.remove()
                }
                "function" == typeof f.end[a] && f.end[a](), delete f.end[a], "function" == typeof o && o(), f.events.resize[a] && (c.off("resize", f.events.resize[a]), delete f.events.resize[a])
            }, l.data("isOutAnim") && l.addClass("layer-anim layer-anim-close"), h("#layui-layer-moves, #" + d.SHADE + a).remove(), 6 == m.ie && f.reselect(), f.rescollbar(a), l.attr("minLeft") && (f.minIndex--, f.minLeft.push(l.attr("minLeft"))), m.ie && m.ie < 10 || !l.data("isOutAnim") ? t() : setTimeout(function() {
                t()
            }, 200))
        }, m.closeAll = function(n, a) {
            "function" == typeof n && (a = n, n = null);
            var o = h("." + d[0]);
            h.each(o, function(e) {
                var t = h(this),
                    i = n ? t.attr("type") === n : 1;
                i && m.close(t.attr("times"), e === o.length - 1 ? a : null)
            }), 0 === o.length && "function" == typeof a && a()
        }, m.cache || {}),
        g = function(e) {
            return i.skin ? " " + i.skin + " " + i.skin + "-" + e : ""
        };
    m.prompt = function(i, n) {
        var e = "";
        "function" == typeof(i = i || {}) && (n = i), i.area && (e = 'style="width: ' + (t = i.area)[0] + "; height: " + t[1] + ';"', delete i.area);
        var a, t = 2 == i.formType ? '<textarea class="layui-layer-input"' + e + "></textarea>" : '<input type="' + (1 == i.formType ? "password" : "text") + '" class="layui-layer-input">',
            o = i.success;
        return delete i.success, m.open(h.extend({
            type: 1,
            btn: ["&#x786E;&#x5B9A;", "&#x53D6;&#x6D88;"],
            content: t,
            skin: "layui-layer-prompt" + g("prompt"),
            maxWidth: c.width(),
            success: function(e) {
                (a = e.find(".layui-layer-input")).val(i.value || "").focus(), "function" == typeof o && o(e)
            },
            resize: !1,
            yes: function(e) {
                var t = a.val();
                "" === t ? a.focus() : t.length > (i.maxlength || 500) ? m.tips("&#x6700;&#x591A;&#x8F93;&#x5165;" + (i.maxlength || 500) + "&#x4E2A;&#x5B57;&#x6570;", a, {
                    tips: 1
                }) : n && n(t, e, a)
            }
        }, i))
    }, m.tab = function(n) {
        var a = (n = n || {}).tab || {},
            o = "layui-this",
            s = n.success;
        return delete n.success, m.open(h.extend({
            type: 1,
            skin: "layui-layer-tab" + g("tab"),
            resize: !1,
            title: function() {
                var e = a.length,
                    t = 1,
                    i = "";
                if (0 < e) for (i = '<span class="' + o + '">' + a[0].title + "</span>"; t < e; t++) i += "<span>" + a[t].title + "</span>";
                return i
            }(),
            content: '<ul class="layui-layer-tabmain">' +
            function() {
                var e = a.length,
                    t = 1,
                    i = "";
                if (0 < e) for (i = '<li class="layui-layer-tabli ' + o + '">' + (a[0].content || "no content") + "</li>"; t < e; t++) i += '<li class="layui-layer-tabli">' + (a[t].content || "no  content") + "</li>";
                return i
            }() + "</ul>",
            success: function(e) {
                var t = e.find(".layui-layer-title").children(),
                    i = e.find(".layui-layer-tabmain").children();
                t.on("mousedown", function(e) {
                    e.stopPropagation ? e.stopPropagation() : e.cancelBubble = !0;
                    var e = h(this),
                        t = e.index();
                    e.addClass(o).siblings().removeClass(o), i.eq(t).show().siblings().hide(), "function" == typeof n.change && n.change(t)
                }), "function" == typeof s && s(e)
            }
        }, n))
    }, m.photos = function(n, e, a) {
        var o = {};
        if ((n = n || {}).photos) {
            var t = !("string" == typeof n.photos || n.photos instanceof h),
                i = t ? n.photos : {},
                s = i.data || [],
                l = i.start || 0,
                r = (o.imgIndex = 1 + (0 | l), n.img = n.img || "img", n.success);
            if (delete n.success, t) {
                if (0 === s.length) return m.msg("&#x6CA1;&#x6709;&#x56FE;&#x7247;")
            } else {
                var c = h(n.photos),
                    f = function() {
                        s = [], c.find(n.img).each(function(e) {
                            var t = h(this);
                            t.attr("layer-index", e), s.push({
                                alt: t.attr("alt"),
                                pid: t.attr("layer-pid"),
                                src: t.attr("layer-src") || t.attr("src"),
                                thumb: t.attr("src")
                            })
                        })
                    };
                if (f(), 0 === s.length) return;
                if (e || c.on("click", n.img, function() {
                    f();
                    var e = h(this).attr("layer-index");
                    m.photos(h.extend(n, {
                        photos: {
                            start: e,
                            data: s,
                            tab: n.tab
                        },
                        full: n.full
                    }), !0)
                }), !e) return
            }
            o.imgprev = function(e) {
                o.imgIndex--, o.imgIndex < 1 && (o.imgIndex = s.length), o.tabimg(e)
            }, o.imgnext = function(e, t) {
                o.imgIndex++, o.imgIndex > s.length && (o.imgIndex = 1, t) || o.tabimg(e)
            }, o.keyup = function(e) {
                var t;
                o.end || (t = e.keyCode, e.preventDefault(), 37 === t ? o.imgprev(!0) : 39 === t ? o.imgnext(!0) : 27 === t && m.close(o.index))
            }, o.tabimg = function(e) {
                if (!(s.length <= 1)) return i.start = o.imgIndex - 1, m.close(o.index), m.photos(n, !0, e)
            }, o.event = function() {
                o.bigimg.find(".layui-layer-imgprev").on("click", function(e) {
                    e.preventDefault(), o.imgprev(!0)
                }), o.bigimg.find(".layui-layer-imgnext").on("click", function(e) {
                    e.preventDefault(), o.imgnext(!0)
                }), h(document).on("keyup", o.keyup)
            }, o.loadi = m.load(1, {
                shade: !("shade" in n) && .9,
                scrollbar: !1
            });
            var t = s[l].src,
                d = function(e) {
                    m.close(o.loadi);
                    var t, i = s[l].alt || "";
                    a && (n.anim = -1), o.index = m.open(h.extend({
                        type: 1,
                        id: "layui-layer-photos",
                        area: (e = [e.width, e.height], t = [h(p).width() - 100, h(p).height() - 100], !n.full && (e[0] > t[0] || e[1] > t[1]) && ((t = [e[0] / t[0], e[1] / t[1]])[1] < t[0] ? (e[0] = e[0] / t[0], e[1] = e[1] / t[0]) : t[0] < t[1] && (e[0] = e[0] / t[1], e[1] = e[1] / t[1])), [e[0] + "px", e[1] + "px"]),
                        title: !1,
                        shade: .9,
                        shadeClose: !0,
                        closeBtn: !1,
                        move: ".layui-layer-phimg img",
                        moveType: 1,
                        scrollbar: !1,
                        moveOut: !0,
                        anim: 5,
                        isOutAnim: !1,
                        skin: "layui-layer-photos" + g("photos"),
                        content: '<div class="layui-layer-phimg"><img src="' + s[l].src + '" alt="' + i + '" layer-pid="' + s[l].pid + '">' + (t = ['<div class="layui-layer-imgsee">'], 1 < s.length && t.push(['<div class="layui-layer-imguide">', '<span class="layui-icon layui-icon-left layui-layer-iconext layui-layer-imgprev"></span>', '<span class="layui-icon layui-icon-right layui-layer-iconext layui-layer-imgnext"></span>', "</div>"].join("")), n.hideFooter || t.push(['<div class="layui-layer-imgbar">', '<div class="layui-layer-imgtit">', "<h3>" + i + "</h3>", "<em>" + o.imgIndex + " / " + s.length + "</em>", '<a href="' + s[l].src + '" target="_blank">\u67e5\u770b\u539f\u56fe</a>', "</div>", "</div>"].join("")), t.push("</div>"), t.join("")) + "</div>",
                        success: function(e, t) {
                            o.bigimg = e.find(".layui-layer-phimg"), o.imgsee = e.find(".layui-layer-imgbar"), o.event(e), n.tab && n.tab(s[l], e), "function" == typeof r && r(e)
                        },
                        end: function() {
                            o.end = !0, h(document).off("keyup", o.keyup)
                        }
                    }, n))
                },
                u = function() {
                    m.close(o.loadi), m.msg("&#x5F53;&#x524D;&#x56FE;&#x7247;&#x5730;&#x5740;&#x5F02;&#x5E38;<br>&#x662F;&#x5426;&#x7EE7;&#x7EED;&#x67E5;&#x770B;&#x4E0B;&#x4E00;&#x5F20;&#xFF1F;", {
                        time: 3e4,
                        btn: ["&#x4E0B;&#x4E00;&#x5F20;", "&#x4E0D;&#x770B;&#x4E86;"],
                        yes: function() {
                            1 < s.length && o.imgnext(!0, !0)
                        }
                    })
                },
                y = new Image;
            (y.src = t, y.complete) ? d(y) : (y.onload = function() {
                y.onload = null, d(y)
            }, y.onerror = function(e) {
                y.onerror = null, u(e)
            })
        }
    }, f.run = function(e) {
        c = (h = e)(p), d.html = h("html"), m.open = function(e) {
            return new t(e).index
        }
    }, p.layui && layui.define ? (m.ready(), layui.define("jquery", function(e) {
        m.path = layui.cache.dir, f.run(layui.$), e("layer", p.layer = m)
    })) : "function" == typeof define && define.amd ? define(["jquery"], function() {
        return f.run(p.jQuery), m
    }) : (m.ready(), f.run(p.jQuery))
}(window);
layui.define("jquery", function(e) {
    "use strict";
    var s = layui.$,
        o = layui.hint(),
        a = {
            fixbar: function(i) {
                var a, e, t, n, o = "layui-fixbar",
                    r = s(document),
                    l = (i = s.extend(!0, {
                        target: "body",
                        bars: [],
                        "default": !0,
                        showHeight: 200,
                        duration: 200
                    }, i), s(i.target)),
                    c = i.scroll ? s(i.scroll) : s("body" === i.target ? r : l),
                    u = (i["default"] && (i.bar1 && i.bars.push({
                        type: "bar1",
                        icon: "layui-icon-chat"
                    }), i.bar2 && i.bars.push({
                        type: "bar2",
                        icon: "layui-icon-help"
                    }), i.bars.push({
                        type: "top",
                        icon: "layui-icon-top"
                    })), s("<ul>").addClass(o));
                layui.each(i.bars, function(e, t) {
                    var n = s('<li class="layui-icon">');
                    n.addClass(t.icon).attr({
                        "lay-type": t.type,
                        style: t.style || "background-color: " + i.bgcolor
                    }).html(t.content), n.on("click", function() {
                        var e = s(this).attr("lay-type");
                        "top" === e && ("body" === i.target ? s("html,body") : c).animate({
                            scrollTop: 0
                        }, i.duration), "function" == typeof i.click && i.click.call(this, e)
                    }), "object" === layui.type(i.on) && layui.each(i.on, function(e, t) {
                        n.on(e, function() {
                            var e = s(this).attr("lay-type");
                            "function" == typeof t && t.call(this, e)
                        })
                    }), "top" === t.type && (n.addClass("layui-fixbar-top"), a = n), u.append(n)
                }), l.find("." + o).remove(), "object" == typeof i.css && u.css(i.css), l.append(u), a && (t = function t() {
                    return c.scrollTop() >= i.showHeight ? e || (a.show(), e = 1) : e && (a.hide(), e = 0), t
                }()), c.on("scroll", function() {
                    t && (clearTimeout(n), n = setTimeout(function() {
                        t()
                    }, 100))
                })
            },
            countdown: function(e, t, n) {
                var i = this,
                    a = "function" == typeof t,
                    o = new Date(e).getTime(),
                    r = new Date(!t || a ? (new Date).getTime() : t).getTime(),
                    o = o - r,
                    l = [Math.floor(o / 864e5), Math.floor(o / 36e5) % 24, Math.floor(o / 6e4) % 60, Math.floor(o / 1e3) % 60],
                    a = (a && (n = t), setTimeout(function() {
                        i.countdown(e, r + 1e3, n)
                    }, 1e3));
                return n && n(0 < o ? l : [0, 0, 0, 0], t, a), o <= 0 && clearTimeout(a), a
            },
            timeAgo: function(e, t) {
                var n = this,
                    i = [
                        [],
                        []
                    ],
                    a = (new Date).getTime() - new Date(e).getTime();
                return 26784e5 < a ? (a = new Date(e), i[0][0] = n.digit(a.getFullYear(), 4), i[0][1] = n.digit(a.getMonth() + 1), i[0][2] = n.digit(a.getDate()), t || (i[1][0] = n.digit(a.getHours()), i[1][1] = n.digit(a.getMinutes()), i[1][2] = n.digit(a.getSeconds())), i[0].join("-") + " " + i[1].join(":")) : 864e5 <= a ? (a / 1e3 / 60 / 60 / 24 | 0) + "\u5929\u524d" : 36e5 <= a ? (a / 1e3 / 60 / 60 | 0) + "\u5c0f\u65f6\u524d" : 18e4 <= a ? (a / 1e3 / 60 | 0) + "\u5206\u949f\u524d" : a < 0 ? "\u672a\u6765" : "\u521a\u521a"
            },
            digit: function(e, t) {
                var n = "";
                t = t || 2;
                for (var i = (e = String(e)).length; i < t; i++) n += "0";
                return e < Math.pow(10, t) ? n + (0 | e) : e
            },
            toDateString: function(e, t) {
                if (null === e || "" === e) return "";
                var n = this,
                    i = new Date(function() {
                        if (e) return !isNaN(e) && "string" == typeof e ? parseInt(e) : e
                    }() || new Date),
                    a = [n.digit(i.getFullYear(), 4), n.digit(i.getMonth() + 1), n.digit(i.getDate())],
                    n = [n.digit(i.getHours()), n.digit(i.getMinutes()), n.digit(i.getSeconds())];
                return i.getDate() ? (t = t || "yyyy-MM-dd HH:mm:ss").replace(/yyyy/g, a[0]).replace(/MM/g, a[1]).replace(/dd/g, a[2]).replace(/HH/g, n[0]).replace(/mm/g, n[1]).replace(/ss/g, n[2]) : (o.error('Invalid Msec for "util.toDateString(Msec)"'), "")
            },
            escape: function(e) {
                return e === undefined || null === e ? "" : /[<"'>]|&(?=#[a-zA-Z0-9]+)/g.test(e += "") ? e.replace(/&(?!#?[a-zA-Z0-9]+;)/g, "&amp;").replace(/</g, "&lt;").replace(/>/g, "&gt;").replace(/'/g, "&#39;").replace(/"/g, "&quot;") : e
            },
            unescape: function(e) {
                return e !== undefined && null !== e || (e = ""), (e += "").replace(/\&amp;/g, "&").replace(/\&lt;/g, "<").replace(/\&gt;/g, ">").replace(/\&#39;/g, "'").replace(/\&quot;/g, '"')
            },
            toVisibleArea: function(e) {
                var t, n, i, a, o, r, l, c;
                (e = s.extend({
                    margin: 160,
                    duration: 200,
                    type: "y"
                }, e)).scrollElem[0] && e.thisElem[0] && (t = e.scrollElem, l = e.thisElem, i = (o = "y" === e.type) ? "top" : "left", a = t[n = o ? "scrollTop" : "scrollLeft"](), o = t[o ? "height" : "width"](), r = t.offset()[i], c = {}, ((l = l.offset()[i] - r) > o - e.margin || l < e.margin) && (c[n] = l - o / 2 + a, t.animate(c, e.duration)))
            },
            event: function(n, i, e) {
                var t = s("body");
                return e = e || "click", i = a.event[n] = s.extend(!0, a.event[n], i) || {}, a.event.UTIL_EVENT_CALLBACK = a.event.UTIL_EVENT_CALLBACK || {}, t.off(e, "*[" + n + "]", a.event.UTIL_EVENT_CALLBACK[n]), a.event.UTIL_EVENT_CALLBACK[n] = function() {
                    var e = s(this),
                        t = e.attr(n);
                    "function" == typeof i[t] && i[t].call(this, e)
                }, t.on(e, "*[" + n + "]", a.event.UTIL_EVENT_CALLBACK[n]), i
            }
        };
    a.on = a.event, e("util", a)
});
layui.define(["jquery", "laytpl", "lay"], function(e) {
    "use strict";
    var n, i, t, s = layui.$,
        m = layui.laytpl,
        a = layui.hint(),
        o = layui.device().mobile ? "click" : "mousedown",
        r = "dropdown",
        c = "layui_" + r + "_index",
        p = {
            config: {},
            index: layui[r] ? layui[r].index + 1e4 : 0,
            set: function(e) {
                var i = this;
                return i.config = s.extend({}, i.config, e), i
            },
            on: function(e, i) {
                return layui.onevent.call(this, r, e, i)
            }
        },
        y = function() {
            var i = this,
                e = i.config,
                t = e.id;
            return y.that[t] = i, {
                config: e,
                reload: function(e) {
                    i.reload.call(i, e)
                }
            }
        },
        l = "layui-menu-item-up",
        u = "layui-menu-item-down",
        f = "layui-menu-body-title",
        d = "layui-menu-item-group",
        g = "layui-menu-item-parent",
        h = "layui-menu-item-checked",
        v = "layui-menu-item-checked2",
        w = "layui-menu-body-panel",
        C = "layui-menu-body-panel-left",
        k = "." + d + ">." + f,
        V = function(e) {
            var i = this;
            i.index = ++p.index, i.config = s.extend({}, i.config, p.config, e), i.init()
        };
    V.prototype.config = {
        trigger: "click",
        content: "",
        className: "",
        style: "",
        show: !1,
        isAllowSpread: !0,
        isSpreadItem: !0,
        data: [],
        delay: 300
    }, V.prototype.reload = function(e) {
        var i = this;
        i.config = s.extend({}, i.config, e), i.init(!0)
    }, V.prototype.init = function(e) {
        var i = this,
            t = i.config,
            n = t.elem = s(t.elem);
        return 1 < n.length ? (layui.each(n, function() {
            p.render(s.extend({}, t, {
                elem: this
            }))
        }), i) : !e && n[0] && n.data(c) ? (n = y.getThis(n.data(c))) ? n.reload(t) : void 0 : (t.id = "id" in t ? t.id : i.index, t.show && i.render(e), void i.events())
    }, V.prototype.render = function(e) {
        var l = this,
            u = l.config,
            i = s("body"),
            d = function(r, e) {
                return layui.each(e, function(e, i) {
                    var t, n = i.child && 0 < i.child.length,
                        a = ("isSpreadItem" in i ? i : u).isSpreadItem,
                        l = i.templet ? m(i.templet).render(i) : u.templet ? m(u.templet).render(i) : i.title,
                        o = (n && (i.type = i.type || "parent"), i.type ? {
                            group: "group",
                            parent: "parent",
                            "-": "-"
                        }[i.type] || "parent" : "");
                    ("-" === o || i.title || i.id || n) && ((l = s(["<li" + (t = {
                        group: "layui-menu-item-group" + (u.isAllowSpread ? a ? " layui-menu-item-down" : " layui-menu-item-up" : ""),
                        parent: g,
                        "-": "layui-menu-item-divider"
                    }, n || o ? ' class="' + t[o] + '"' : "") + ">", (t = "href" in i ? '<a href="' + i.href + '" target="' + (i.target || "_self") + '">' + l + "</a>" : l, n ? '<div class="' + f + '">' + t + ("parent" === o ? '<i class="layui-icon layui-icon-right"></i>' : "group" === o && u.isAllowSpread ? '<i class="layui-icon layui-icon-' + (a ? "up" : "down") + '"></i>' : "") + "</div>" : '<div class="' + f + '">' + t + "</div>"), "</li>"].join(""))).data("item", i), n && (a = s('<div class="layui-panel layui-menu-body-panel"></div>'), t = s("<ul></ul>"), "parent" === o ? (a.append(d(t, i.child)), l.append(a)) : l.append(d(t, i.child))), r.append(l))
                }), r
            },
            t = ['<div class="layui-dropdown layui-border-box layui-panel layui-anim layui-anim-downbit">', "</div>"].join("");
        !(e = "contextMenu" !== u.trigger && !lay.isTopElem(u.elem[0]) ? e : !0) && u.elem.data(c + "_opened") || (l.elemView = s(t), l.elemView.append(u.content || (e = s('<ul class="layui-menu layui-dropdown-menu"></ul>'), 0 < u.data.length ? d(e, u.data) : e.html('<li class="layui-menu-item-none">no menu</li>'), e)), u.className && l.elemView.addClass(u.className), u.style && l.elemView.attr("style", u.style), p.thisId = u.id, l.remove(), i.append(l.elemView), u.elem.data(c + "_opened", !0), l.position(), (y.prevElem = l.elemView).data("prevElem", u.elem), l.elemView.find(".layui-menu").on(o, function(e) {
            layui.stope(e)
        }), l.elemView.find(".layui-menu li").on("click", function(e) {
            var i = s(this),
                t = i.data("item") || {},
                n = t.child && 0 < t.child.length,
                a = "all" === u.clickScope;
            n && !a || "-" === t.type || (n || l.remove(), "function" == typeof u.click && u.click(t, i), layui.stope(e))
        }), l.elemView.find(k).on("click", function(e) {
            var i = s(this).parent();
            "group" === (i.data("item") || {}).type && u.isAllowSpread && y.spread(i)
        }), "mouseenter" === u.trigger && l.elemView.on("mouseenter", function() {
            clearTimeout(y.timer)
        }).on("mouseleave", function() {
            l.delayRemove()
        }))
    }, V.prototype.position = function(e) {
        var i = this.config;
        lay.position(i.elem[0], this.elemView[0], {
            position: i.position,
            e: this.e,
            clickType: "contextMenu" === i.trigger ? "right" : null,
            align: i.align || null
        })
    }, V.prototype.remove = function() {
        this.config;
        var e = y.prevElem;
        e && (e.data("prevElem") && e.data("prevElem").data(c + "_opened", !1), e.remove())
    }, V.prototype.delayRemove = function() {
        var e = this,
            i = e.config;
        clearTimeout(y.timer), y.timer = setTimeout(function() {
            e.remove()
        }, i.delay)
    }, V.prototype.events = function() {
        var i = this,
            t = i.config;
        "hover" === t.trigger && (t.trigger = "mouseenter"), i.prevElem && i.prevElem.off(t.trigger, i.prevElemCallback), i.prevElem = t.elem, i.prevElemCallback = function(e) {
            clearTimeout(y.timer), i.e = e, i.render(), e.preventDefault(), "function" == typeof t.ready && t.ready(i.elemView, t.elem, i.e.target)
        }, t.elem.on(t.trigger, i.prevElemCallback), "mouseenter" === t.trigger && t.elem.on("mouseleave", function() {
            i.delayRemove()
        })
    }, y.that = {}, y.getThis = function(e) {
        var i = y.that[e];
        return i || a.error(e ? r + " instance with ID '" + e + "' not found" : "ID argument required"), i
    }, y.spread = function(e) {
        var i = e.children("." + f).find(".layui-icon");
        e.hasClass(l) ? (e.removeClass(l).addClass(u), i.removeClass("layui-icon-down").addClass("layui-icon-up")) : (e.removeClass(u).addClass(l), i.removeClass("layui-icon-up").addClass("layui-icon-down"))
    }, n = s(window), i = s(document), n.on("resize", function() {
        if (p.thisId) {
            var e = y.getThis(p.thisId);
            if (e) {
                if (!e.elemView[0] || !s(".layui-dropdown")[0]) return !1;
                "contextMenu" === e.config.trigger ? e.remove() : e.position()
            }
        }
    }), i.on(o, function(e) {
        var i, t;
        !p.thisId || (i = y.getThis(p.thisId)) && (t = i.config, !lay.isTopElem(t.elem[0]) && "contextMenu" !== t.trigger && (e.target === t.elem[0] || t.elem.find(e.target)[0] || e.target === i.elemView[0] || i.elemView && i.elemView.find(e.target)[0]) || i.remove())
    }), t = ".layui-menu:not(.layui-dropdown-menu) li", i.on("click", t, function(e) {
        var i = s(this),
            t = i.parents(".layui-menu").eq(0),
            n = i.hasClass(d) || i.hasClass(g),
            a = t.attr("lay-filter") || t.attr("id"),
            l = lay.options(this);
        i.hasClass("layui-menu-item-divider") || n || (t.find("." + h).removeClass(h), t.find("." + v).removeClass(v), i.addClass(h), i.parents("." + g).addClass(v), layui.event.call(this, r, "click(" + a + ")", l))
    }), i.on("click", t + k, function(e) {
        var i = s(this).parents("." + d + ":eq(0)"),
            t = lay.options(i[0]);
        "isAllowSpread" in t && !t.isAllowSpread || y.spread(i)
    }), t = ".layui-menu ." + g, i.on("mouseenter", t, function(e) {
        var i, t = s(this).find("." + w);
        t[0] && ((i = t[0].getBoundingClientRect()).right > n.width() && (t.addClass(C), (i = t[0].getBoundingClientRect()).left < 0 && t.removeClass(C)), i.bottom > n.height() && t.eq(0).css("margin-top", -(i.bottom - n.height() + 5)))
    }).on("mouseleave", t, function(e) {
        var i = s(this).children("." + w);
        i.removeClass(C), i.css("margin-top", 0)
    }), p.reload = function(e, i) {
        e = y.getThis(e);
        return e ? (e.reload(i), y.call(e)) : this
    }, p.render = function(e) {
        e = new V(e);
        return y.call(e)
    }, e(r, p)
});
layui.define("jquery", function(e) {
    "use strict";
    var g = layui.$,
        t = {
            config: {},
            index: layui.slider ? layui.slider.index + 1e4 : 0,
            set: function(e) {
                var i = this;
                return i.config = g.extend({}, i.config, e), i
            },
            on: function(e, i) {
                return layui.onevent.call(this, a, e, i)
            }
        },
        a = "slider",
        c = "layui-disabled",
        b = "layui-slider-bar",
        x = "layui-slider-wrap",
        T = "layui-slider-wrap-btn",
        w = "layui-slider-tips",
        M = "layui-slider-input-txt",
        L = "layui-slider-hover",
        i = function(e) {
            var i = this;
            i.index = ++t.index, i.config = g.extend({}, i.config, t.config, e), i.render()
        };
    i.prototype.config = {
        type: "default",
        min: 0,
        max: 100,
        value: 0,
        step: 1,
        showstep: !1,
        tips: !0,
        input: !1,
        range: !1,
        height: 200,
        disabled: !1,
        theme: "#009688"
    }, i.prototype.render = function() {
        var a, n = this,
            l = n.config,
            e = (l.step < 1 && (l.step = 1), l.max < l.min && (l.max = l.min + l.step), l.range ? (l.value = "object" == typeof l.value ? l.value : [l.min, l.value], i = Math.min(l.value[0], l.value[1]), s = Math.max(l.value[0], l.value[1]), l.value[0] = i > l.min ? i : l.min, l.value[1] = s > l.min ? s : l.min, l.value[0] = l.value[0] > l.max ? l.max : l.value[0], l.value[1] = l.value[1] > l.max ? l.max : l.value[1], i = Math.floor((l.value[0] - l.min) / (l.max - l.min) * 100), t = (s = Math.floor((l.value[1] - l.min) / (l.max - l.min) * 100)) - i + "%", i += "%", s += "%") : ("object" == typeof l.value && (l.value = Math.min.apply(null, l.value)), l.value < l.min && (l.value = l.min), l.value > l.max && (l.value = l.max), t = Math.floor((l.value - l.min) / (l.max - l.min) * 100) + "%"), l.disabled ? "#c2c2c2" : l.theme),
            i = '<div class="layui-slider ' + ("vertical" === l.type ? "layui-slider-vertical" : "") + '">' + (l.tips ? '<div class="' + w + '"></div>' : "") + '<div class="layui-slider-bar" style="background:' + e + "; " + ("vertical" === l.type ? "height" : "width") + ":" + t + ";" + ("vertical" === l.type ? "bottom" : "left") + ":" + (i || 0) + ';"></div><div class="layui-slider-wrap" style="' + ("vertical" === l.type ? "bottom" : "left") + ":" + (i || t) + ';"><div class="layui-slider-wrap-btn" style="border: 2px solid ' + e + ';"></div></div>' + (l.range ? '<div class="layui-slider-wrap" style="' + ("vertical" === l.type ? "bottom" : "left") + ":" + s + ';"><div class="layui-slider-wrap-btn" style="border: 2px solid ' + e + ';"></div></div>' : "") + "</div>",
            t = g(l.elem),
            s = t.next(".layui-slider");
        if (s[0] && s.remove(), n.elemTemp = g(i), l.range ? (n.elemTemp.find("." + x).eq(0).data("value", l.value[0]), n.elemTemp.find("." + x).eq(1).data("value", l.value[1])) : n.elemTemp.find("." + x).data("value", l.value), t.html(n.elemTemp), "vertical" === l.type && n.elemTemp.height(l.height + "px"), l.showstep) {
            for (var o = (l.max - l.min) / l.step, r = "", u = 1; u < 1 + o; u++) {
                var d = 100 * u / o;
                d < 100 && (r += '<div class="layui-slider-step" style="' + ("vertical" === l.type ? "bottom" : "left") + ":" + d + '%"></div>')
            }
            n.elemTemp.append(r)
        }
        l.input && !l.range && (e = g('<div class="layui-slider-input layui-input"><div class="layui-slider-input-txt"><input type="text" class="layui-input"></div><div class="layui-slider-input-btn"><i class="layui-icon layui-icon-up"></i><i class="layui-icon layui-icon-down"></i></div></div>'), t.css("position", "relative"), t.append(e), t.find("." + M).children("input").val(l.value), "vertical" === l.type ? e.css({
            left: 0,
            top: -48
        }) : n.elemTemp.css("margin-right", e.outerWidth() + 15)), l.disabled ? (n.elemTemp.addClass(c), n.elemTemp.find("." + T).addClass(c)) : n.slide(), n.elemTemp.find("." + T).on("mouseover", function() {
            var e = "vertical" === l.type ? l.height : n.elemTemp[0].offsetWidth,
                i = n.elemTemp.find("." + x),
                t = ("vertical" === l.type ? e - g(this).parent()[0].offsetTop - i.height() : g(this).parent()[0].offsetLeft) / e * 100,
                i = g(this).parent().data("value"),
                e = l.setTips ? l.setTips(i) : i;
            n.elemTemp.find("." + w).html(e), clearTimeout(a), a = setTimeout(function() {
                "vertical" === l.type ? n.elemTemp.find("." + w).css({
                    bottom: t + "%",
                    "margin-bottom": "20px",
                    display: "inline-block"
                }) : n.elemTemp.find("." + w).css({
                    left: t + "%",
                    display: "inline-block"
                })
            }, 300)
        }).on("mouseout", function() {
            clearTimeout(a), n.elemTemp.find("." + w).css("display", "none")
        })
    }, i.prototype.slide = function(e, i, t) {
        var o = this,
            r = o.config,
            u = o.elemTemp,
            d = function() {
                return "vertical" === r.type ? r.height : u[0].offsetWidth
            },
            c = u.find("." + x),
            v = u.next(".layui-slider-input"),
            m = v.children("." + M).children("input").val(),
            p = 100 / ((r.max - r.min) / Math.ceil(r.step)),
            f = function(e, i, t) {
                e = 100 < (e = 100 < Math.ceil(e) * p ? Math.ceil(e) * p : Math.round(e) * p) ? 100 : e, c.eq(i).css("vertical" === r.type ? "bottom" : "left", e + "%");
                var a, n = h(c[0].offsetLeft),
                    l = r.range ? h(c[1].offsetLeft) : 0,
                    s = ("vertical" === r.type ? (u.find("." + w).css({
                        bottom: e + "%",
                        "margin-bottom": "20px"
                    }), n = h(d() - c[0].offsetTop - c.height()), l = r.range ? h(d() - c[1].offsetTop - c.height()) : 0) : u.find("." + w).css("left", e + "%"), n = 100 < n ? 100 : n, l = 100 < l ? 100 : l, Math.min(n, l)),
                    n = Math.abs(n - l),
                    l = ("vertical" === r.type ? u.find("." + b).css({
                        height: n + "%",
                        bottom: s + "%"
                    }) : u.find("." + b).css({
                        width: n + "%",
                        left: s + "%"
                    }), r.min + Math.round((r.max - r.min) * e / 100));
                m = l, v.children("." + M).children("input").val(m), c.eq(i).data("value", l), u.find("." + w).html(r.setTips ? r.setTips(l) : l), r.range && (a = [c.eq(0).data("value"), c.eq(1).data("value")])[0] > a[1] && a.reverse(), o.value = r.range ? a : l, r.change && r.change(o.value), "done" === t && r.done && r.done(o.value)
            },
            h = function(e) {
                var i = e / d() * 100 / p,
                    t = Math.round(i) * p;
                return t = e == d() ? Math.ceil(i) * p : t
            },
            y = g(['<div class="layui-auxiliar-moving" id="LAY-slider-moving"></div'].join(""));
        if ("set" === e) return f(i, t, "done");
        u.find("." + T).each(function(l) {
            var s = g(this);
            s.on("mousedown", function(e) {
                e = e || window.event;
                var i, t, a = s.parent()[0].offsetLeft,
                    n = e.clientX;
                "vertical" === r.type && (a = d() - s.parent()[0].offsetTop - c.height(), n = e.clientY);
                e = function(e) {
                    e = e || window.event;
                    var i = a + ("vertical" === r.type ? n - e.clientY : e.clientX - n),
                        i = (i = (i = i < 0 ? 0 : i) > d() ? d() : i) / d() * 100 / p;
                    f(i, l), s.addClass(L), u.find("." + w).show(), e.preventDefault()
                }, i = function() {
                    s.removeClass(L), u.find("." + w).hide()
                }, t = function() {
                    i && i(), y.remove(), r.done && r.done(o.value)
                }, g("#LAY-slider-moving")[0] || g("body").append(y), y.on("mousemove", e), y.on("mouseup", t).on("mouseleave", t)
            })
        }), u.on("click", function(e) {
            var i = g("." + T),
                t = g(this);
            !i.is(event.target) && 0 === i.has(event.target).length && i.length && (t = (i = (i = (i = "vertical" === r.type ? d() - e.clientY + t.offset().top - g(window).scrollTop() : e.clientX - t.offset().left - g(window).scrollLeft()) < 0 ? 0 : i) > d() ? d() : i) / d() * 100 / p, i = r.range ? "vertical" === r.type ? Math.abs(i - parseInt(g(c[0]).css("bottom"))) > Math.abs(i - parseInt(g(c[1]).css("bottom"))) ? 1 : 0 : Math.abs(i - c[0].offsetLeft) > Math.abs(i - c[1].offsetLeft) ? 1 : 0 : 0, f(t, i, "done"), e.preventDefault())
        }), v.children(".layui-slider-input-btn").children("i").each(function(i) {
            g(this).on("click", function() {
                m = v.children("." + M).children("input").val();
                var e = ((m = 1 == i ? m - r.step < r.min ? r.min : Number(m) - r.step : Number(m) + r.step > r.max ? r.max : Number(m) + r.step) - r.min) / (r.max - r.min) * 100 / p;
                f(e, 0, "done")
            })
        });
        var a = function() {
                var e = this.value,
                    e = (e = (e = (e = isNaN(e) ? 0 : e) < r.min ? r.min : e) > r.max ? r.max : e, ((this.value = e) - r.min) / (r.max - r.min) * 100 / p);
                f(e, 0, "done")
            };
        v.children("." + M).children("input").on("keydown", function(e) {
            13 === e.keyCode && (e.preventDefault(), a.call(this))
        }).on("change", a)
    }, i.prototype.events = function() {
        this.config
    }, t.render = function(e) {
        e = new i(e);
        return function() {
            var t = this,
                a = t.config;
            return {
                setValue: function(e, i) {
                    return a.value = e, t.slide("set", e, i || 0)
                },
                config: a
            }
        }.call(e)
    }, e(a, t)
});
layui.define(["jquery", "lay"], function(e) {
    "use strict";
    var k = layui.$,
        t = layui.lay,
        o = layui.hint(),
        i = layui.device().mobile ? "click" : "mousedown",
        n = {
            config: {},
            index: layui.colorpicker ? layui.colorpicker.index + 1e4 : 0,
            set: function(e) {
                var i = this;
                return i.config = k.extend({}, i.config, e), i
            },
            on: function(e, i) {
                return layui.onevent.call(this, "colorpicker", e, i)
            }
        },
        l = function() {
            var e = this.config,
                i = e.id;
            return l.that[i] = this, {
                config: e
            }
        },
        r = "colorpicker",
        c = "layui-colorpicker",
        a = ".layui-colorpicker-main",
        m = "layui-icon-down",
        x = "layui-icon-close",
        P = "layui-colorpicker-trigger-span",
        C = "layui-colorpicker-trigger-i",
        B = "layui-colorpicker-side-slider",
        w = "layui-colorpicker-basis",
        I = "layui-colorpicker-alpha-bgcolor",
        D = "layui-colorpicker-alpha-slider",
        E = "layui-colorpicker-basis-cursor",
        F = "layui-colorpicker-main-input",
        M = function(e) {
            var i = {
                h: 0,
                s: 0,
                b: 0
            },
                o = Math.min(e.r, e.g, e.b),
                r = Math.max(e.r, e.g, e.b),
                t = r - o;
            return i.b = r, i.s = 0 != r ? 255 * t / r : 0, 0 != i.s ? e.r == r ? i.h = (e.g - e.b) / t : e.g == r ? i.h = 2 + (e.b - e.r) / t : i.h = 4 + (e.r - e.g) / t : i.h = -1, r == o && (i.h = 0), i.h *= 60, i.h < 0 && (i.h += 360), i.s *= 100 / 255, i.b *= 100 / 255, i
        },
        T = function(e) {
            var i, o = {},
                r = e.h,
                t = 255 * e.s / 100,
                e = 255 * e.b / 100;
            return 0 == t ? o.r = o.g = o.b = e : (e = r % 60 * ((i = e) - (t = (255 - t) * e / 255)) / 60, (r = 360 == r ? 0 : r) < 60 ? (o.r = i, o.b = t, o.g = t + e) : r < 120 ? (o.g = i, o.b = t, o.r = i - e) : r < 180 ? (o.g = i, o.r = t, o.b = t + e) : r < 240 ? (o.b = i, o.r = t, o.g = i - e) : r < 300 ? (o.b = i, o.g = t, o.r = t + e) : r < 360 ? (o.r = i, o.g = t, o.b = i - e) : (o.r = 0, o.g = 0, o.b = 0)), {
                r: Math.round(o.r),
                g: Math.round(o.g),
                b: Math.round(o.b)
            }
        },
        f = function(e) {
            var e = T(e),
                o = [e.r.toString(16), e.g.toString(16), e.b.toString(16)];
            return k.each(o, function(e, i) {
                1 == i.length && (o[e] = "0" + i)
            }), o.join("")
        },
        Y = function(e) {
            e = e.match(/[0-9]{1,3}/g) || [];
            return {
                r: e[0],
                g: e[1],
                b: e[2]
            }
        },
        j = k(window),
        s = k(document),
        d = function(e) {
            this.index = ++n.index, this.config = k.extend({}, this.config, n.config, e), this.render()
        };
    d.prototype.config = {
        color: "",
        size: null,
        alpha: !1,
        format: "hex",
        predefine: !1,
        colors: ["#009688", "#5FB878", "#1E9FFF", "#FF5722", "#FFB800", "#01AAED", "#999", "#c00", "#ff8c00", "#ffd700", "#90ee90", "#00ced1", "#1e90ff", "#c71585", "rgb(0, 186, 189)", "rgb(255, 120, 0)", "rgb(250, 212, 0)", "#393D49", "rgba(0,0,0,.5)", "rgba(255, 69, 0, 0.68)", "rgba(144, 240, 144, 0.5)", "rgba(31, 147, 255, 0.73)"]
    }, d.prototype.render = function() {
        var e = this,
            i = e.config,
            o = k(i.elem);
        if (1 < o.length) return layui.each(o, function() {
            n.render(k.extend({}, i, {
                elem: this
            }))
        }), e;
        k.extend(i, t.options(o[0]));
        var o = k(['<div class="layui-unselect layui-colorpicker">', "<span " + ("rgb" == i.format && i.alpha ? 'class="layui-colorpicker-trigger-bgcolor"' : "") + ">", '<span class="layui-colorpicker-trigger-span" ', 'lay-type="' + ("rgb" == i.format ? i.alpha ? "rgba" : "torgb" : "") + '" ', 'style="' + (o = "", i.color ? (o = i.color, 3 < (i.color.match(/[0-9]{1,3}/g) || []).length && (i.alpha && "rgb" == i.format || (o = "#" + f(M(Y(i.color))))), "background: " + o) : o) + '">', '<i class="layui-icon layui-colorpicker-trigger-i ' + (i.color ? m : x) + '"></i>', "</span>", "</span>", "</div>"].join("")),
            r = i.elem = k(i.elem);
        i.size && o.addClass("layui-colorpicker-" + i.size), r.addClass("layui-inline").html(e.elemColorBox = o), i.id = "id" in i ? i.id : e.index, e.color = e.elemColorBox.find("." + P)[0].style.background, e.events()
    }, d.prototype.renderPicker = function() {
        var o, e = this,
            i = e.config,
            r = e.elemColorBox[0],
            t = e.elemPicker = k(['<div id="layui-colorpicker' + e.index + '" data-index="' + e.index + '" class="layui-anim layui-anim-downbit layui-colorpicker-main">', '<div class="layui-colorpicker-main-wrapper">', '<div class="layui-colorpicker-basis">', '<div class="layui-colorpicker-basis-white"></div>', '<div class="layui-colorpicker-basis-black"></div>', '<div class="layui-colorpicker-basis-cursor"></div>', "</div>", '<div class="layui-colorpicker-side">', '<div class="layui-colorpicker-side-slider"></div>', "</div>", "</div>", '<div class="layui-colorpicker-main-alpha ' + (i.alpha ? "layui-show" : "") + '">', '<div class="layui-colorpicker-alpha-bgcolor">', '<div class="layui-colorpicker-alpha-slider"></div>', "</div>", "</div>", i.predefine ? (o = ['<div class="layui-colorpicker-main-pre">'], layui.each(i.colors, function(e, i) {
                o.push(['<div class="layui-colorpicker-pre' + (3 < (i.match(/[0-9]{1,3}/g) || []).length ? " layui-colorpicker-pre-isalpha" : "") + '">', '<div style="background:' + i + '"></div>', "</div>"].join(""))
            }), o.push("</div>"), o.join("")) : "", '<div class="layui-colorpicker-main-input">', '<div class="layui-inline">', '<input type="text" class="layui-input">', "</div>", '<div class="layui-btn-container">', '<button class="layui-btn layui-btn-primary layui-btn-sm" colorpicker-events="clear">\u6e05\u7a7a</button>', '<button class="layui-btn layui-btn-sm" colorpicker-events="confirm">\u786e\u5b9a</button>', "</div", "</div>", "</div>"].join(""));
        e.elemColorBox.find("." + P)[0];
        k(a)[0] && k(a).data("index") == e.index ? e.removePicker(d.thisElemInd) : (e.removePicker(d.thisElemInd), k("body").append(t)), n.thisId = i.id, d.thisElemInd = e.index, d.thisColor = r.style.background, e.position(), e.pickerEvents()
    }, d.prototype.removePicker = function(e) {
        var i = this.config,
            e = k("#layui-colorpicker" + (e || this.index));
        return e[0] && (e.remove(), delete n.thisId, "function" == typeof i.close && i.close(this.color)), this
    }, d.prototype.position = function() {
        var e = this,
            i = e.config;
        return t.position(e.bindElem || e.elemColorBox[0], e.elemPicker[0], {
            position: i.position,
            align: "center"
        }), e
    }, d.prototype.val = function() {
        var e, i = this,
            o = (i.config, i.elemColorBox.find("." + P)),
            r = i.elemPicker.find("." + F),
            t = o[0].style.backgroundColor;
        t ? (e = M(Y(t)), o = o.attr("lay-type"), i.select(e.h, e.s, e.b), "torgb" === o && r.find("input").val(t), "rgba" === o && (e = Y(t), 3 == (t.match(/[0-9]{1,3}/g) || []).length ? (r.find("input").val("rgba(" + e.r + ", " + e.g + ", " + e.b + ", 1)"), i.elemPicker.find("." + D).css("left", 280)) : (r.find("input").val(t), o = 280 * t.slice(t.lastIndexOf(",") + 1, t.length - 1), i.elemPicker.find("." + D).css("left", o)), i.elemPicker.find("." + I)[0].style.background = "linear-gradient(to right, rgba(" + e.r + ", " + e.g + ", " + e.b + ", 0), rgb(" + e.r + ", " + e.g + ", " + e.b + "))")) : (i.select(0, 100, 100), r.find("input").val(""), i.elemPicker.find("." + I)[0].style.background = "", i.elemPicker.find("." + D).css("left", 280))
    }, d.prototype.side = function() {
        var t = this,
            n = t.config,
            l = t.elemColorBox.find("." + P),
            c = l.attr("lay-type"),
            a = t.elemPicker.find(".layui-colorpicker-side"),
            e = t.elemPicker.find("." + B),
            s = t.elemPicker.find("." + w),
            r = t.elemPicker.find("." + E),
            d = t.elemPicker.find("." + I),
            f = t.elemPicker.find("." + D),
            u = e[0].offsetTop / 180 * 360,
            g = 100 - (r[0].offsetTop + 3) / 180 * 100,
            p = (r[0].offsetLeft + 3) / 260 * 100,
            h = Math.round(f[0].offsetLeft / 280 * 100) / 100,
            v = t.elemColorBox.find("." + C),
            i = t.elemPicker.find(".layui-colorpicker-pre").children("div"),
            y = function(e, i, o, r) {
                t.select(e, i, o);
                e = T({
                    h: e,
                    s: i,
                    b: o
                });
                v.addClass(m).removeClass(x), l[0].style.background = "rgb(" + e.r + ", " + e.g + ", " + e.b + ")", "torgb" === c && t.elemPicker.find("." + F).find("input").val("rgb(" + e.r + ", " + e.g + ", " + e.b + ")"), "rgba" === c && (f.css("left", 280 * r), t.elemPicker.find("." + F).find("input").val("rgba(" + e.r + ", " + e.g + ", " + e.b + ", " + r + ")"), l[0].style.background = "rgba(" + e.r + ", " + e.g + ", " + e.b + ", " + r + ")", d[0].style.background = "linear-gradient(to right, rgba(" + e.r + ", " + e.g + ", " + e.b + ", 0), rgb(" + e.r + ", " + e.g + ", " + e.b + "))"), n.change && n.change(t.elemPicker.find("." + F).find("input").val())
            },
            o = k(['<div class="layui-auxiliar-moving" id="LAY-colorpicker-moving"></div>'].join("")),
            b = function(e) {
                k("#LAY-colorpicker-moving")[0] || k("body").append(o), o.on("mousemove", e), o.on("mouseup", function() {
                    o.remove()
                }).on("mouseleave", function() {
                    o.remove()
                })
            };
        e.on("mousedown", function(e) {
            var r = this.offsetTop,
                t = e.clientY;
            b(function(e) {
                var i = r + (e.clientY - t),
                    o = a[0].offsetHeight,
                    o = (i = o < (i = i < 0 ? 0 : i) ? o : i) / 180 * 360;
                y(u = o, p, g, h), e.preventDefault()
            }), e.preventDefault()
        }), a.on("click", function(e) {
            var i = e.clientY - k(this).offset().top,
                i = (i = (i = i < 0 ? 0 : i) > this.offsetHeight ? this.offsetHeight : i) / 180 * 360;
            y(u = i, p, g, h), e.preventDefault()
        }), r.on("mousedown", function(e) {
            var n = this.offsetTop,
                l = this.offsetLeft,
                c = e.clientY,
                a = e.clientX;
            layui.stope(e), b(function(e) {
                var i = n + (e.clientY - c),
                    o = l + (e.clientX - a),
                    r = s[0].offsetHeight - 3,
                    t = s[0].offsetWidth - 3,
                    t = ((o = t < (o = o < -3 ? -3 : o) ? t : o) + 3) / 260 * 100,
                    o = 100 - ((i = r < (i = i < -3 ? -3 : i) ? r : i) + 3) / 180 * 100;
                y(u, p = t, g = o, h), e.preventDefault()
            }), e.preventDefault()
        }), s.on("mousedown", function(e) {
            var i = e.clientY - k(this).offset().top - 3 + j.scrollTop(),
                o = e.clientX - k(this).offset().left - 3 + j.scrollLeft(),
                o = ((i = i < -3 ? -3 : i) > this.offsetHeight - 3 && (i = this.offsetHeight - 3), ((o = (o = o < -3 ? -3 : o) > this.offsetWidth - 3 ? this.offsetWidth - 3 : o) + 3) / 260 * 100),
                i = 100 - (i + 3) / 180 * 100;
            y(u, p = o, g = i, h), layui.stope(e), e.preventDefault(), r.trigger(e, "mousedown")
        }), f.on("mousedown", function(e) {
            var r = this.offsetLeft,
                t = e.clientX;
            b(function(e) {
                var i = r + (e.clientX - t),
                    o = d[0].offsetWidth,
                    o = (o < (i = i < 0 ? 0 : i) && (i = o), Math.round(i / 280 * 100) / 100);
                y(u, p, g, h = o), e.preventDefault()
            }), e.preventDefault()
        }), d.on("click", function(e) {
            var i = e.clientX - k(this).offset().left,
                i = ((i = i < 0 ? 0 : i) > this.offsetWidth && (i = this.offsetWidth), Math.round(i / 280 * 100) / 100);
            y(u, p, g, h = i), e.preventDefault()
        }), i.each(function() {
            k(this).on("click", function() {
                k(this).parent(".layui-colorpicker-pre").addClass("selected").siblings().removeClass("selected");
                var e = this.style.backgroundColor,
                    i = M(Y(e)),
                    o = e.slice(e.lastIndexOf(",") + 1, e.length - 1);
                u = i.h, p = i.s, g = i.b, 3 == (e.match(/[0-9]{1,3}/g) || []).length && (o = 1), h = o, y(i.h, i.s, i.b, o)
            })
        })
    }, d.prototype.select = function(e, i, o, r) {
        var t = this,
            n = (t.config, f({
                h: e,
                s: 100,
                b: 100
            })),
            l = f({
                h: e,
                s: i,
                b: o
            }),
            e = e / 360 * 180,
            o = 180 - o / 100 * 180 - 3,
            i = i / 100 * 260 - 3;
        t.elemPicker.find("." + B).css("top", e), t.elemPicker.find("." + w)[0].style.background = "#" + n, t.elemPicker.find("." + E).css({
            top: o,
            left: i
        }), "change" !== r && t.elemPicker.find("." + F).find("input").val("#" + l)
    }, d.prototype.pickerEvents = function() {
        var c = this,
            a = c.config,
            s = c.elemColorBox.find("." + P),
            d = c.elemPicker.find("." + F + " input"),
            o = {
                clear: function(e) {
                    s[0].style.background = "", c.elemColorBox.find("." + C).removeClass(m).addClass(x), c.color = "", a.done && a.done(""), c.removePicker()
                },
                confirm: function(e, i) {
                    var o, r, t = d.val(),
                        n = t,
                        l = {};
                    if (-1 < t.indexOf(",") ? (l = M(Y(t)), c.select(l.h, l.s, l.b), s[0].style.background = n = "#" + f(l), 3 < (t.match(/[0-9]{1,3}/g) || []).length && "rgba" === s.attr("lay-type") && (o = 280 * t.slice(t.lastIndexOf(",") + 1, t.length - 1), c.elemPicker.find("." + D).css("left", o), n = s[0].style.background = t)) : (3 == (o = -1 < (o = t).indexOf("#") ? o.substring(1) : o).length && (o = (r = o.split(""))[0] + r[0] + r[1] + r[1] + r[2] + r[2]), r = {
                        r: (o = parseInt(o, 16)) >> 16,
                        g: (65280 & o) >> 8,
                        b: 255 & o
                    }, l = M(r), s[0].style.background = n = "#" + f(l), c.elemColorBox.find("." + C).removeClass(x).addClass(m)), "change" === i) return c.select(l.h, l.s, l.b, i), void(a.change && a.change(n));
                    c.color = t, a.done && a.done(t), c.removePicker()
                }
            };
        c.elemPicker.on("click", "*[colorpicker-events]", function() {
            var e = k(this),
                i = e.attr("colorpicker-events");
            o[i] && o[i].call(this, e)
        }), d.on("keyup", function(e) {
            var i = k(this);
            o.confirm.call(this, i, 13 === e.keyCode ? null : "change")
        })
    }, d.prototype.events = function() {
        var e = this;
        e.config;
        e.elemColorBox.on("click", function() {
            e.renderPicker(), k(a)[0] && (e.val(), e.side())
        })
    }, s.on(i, function(e) {
        var i, o, r;
        !n.thisId || (i = l.getThis(n.thisId)) && (o = i.config, r = i.elemColorBox.find("." + P), k(e.target).hasClass(c) || k(e.target).parents("." + c)[0] || k(e.target).hasClass(a.replace(/\./g, "")) || k(e.target).parents(a)[0] || i.elemPicker && (i.color ? (e = M(Y(i.color)), i.select(e.h, e.s, e.b)) : i.elemColorBox.find("." + C).removeClass(m).addClass(x), r[0].style.background = i.color || "", "function" == typeof o.cancel && o.cancel(i.color), i.removePicker()))
    }), j.on("resize", function() {
        if (n.thisId) {
            var e = l.getThis(n.thisId);
            if (e) return !(!e.elemPicker || !k(a)[0]) && void e.position()
        }
    }), l.that = {}, l.getThis = function(e) {
        var i = l.that[e];
        return i || o.error(e ? r + " instance with ID '" + e + "' not found" : "ID argument required"), i
    }, n.render = function(e) {
        e = new d(e);
        return l.call(e)
    }, e(r, n)
});
layui.define("jquery", function(t) {
    "use strict";
    var u = layui.$,
        d = (layui.hint(), layui.device()),
        c = "element",
        r = "layui-this",
        y = "layui-show",
        i = function() {
            this.config = {}
        },
        h = (i.prototype.set = function(t) {
            return u.extend(!0, this.config, t), this
        }, i.prototype.on = function(t, i) {
            return layui.onevent.call(this, c, t, i)
        }, i.prototype.tabAdd = function(t, i) {
            var a, t = u(".layui-tab[lay-filter=" + t + "]"),
                e = t.children(".layui-tab-title"),
                l = e.children(".layui-tab-bar"),
                t = t.children(".layui-tab-content"),
                n = "<li" + (a = [], layui.each(i, function(t, i) {
                    /^(title|content)$/.test(t) || a.push("lay-" + t + '="' + i + '"')
                }), 0 < a.length && a.unshift(""), a.join(" ")) + ">" + (i.title || "unnaming") + "</li>";
            return l[0] ? l.before(n) : e.append(n), t.append('<div class="layui-tab-item">' + (i.content || "") + "</div>"), C.hideTabMore(!0), C.tabAuto(), this
        }, i.prototype.tabDelete = function(t, i) {
            t = u(".layui-tab[lay-filter=" + t + "]").children(".layui-tab-title").find('>li[lay-id="' + i + '"]');
            return C.tabDelete(null, t), this
        }, i.prototype.tabChange = function(t, i) {
            t = u(".layui-tab[lay-filter=" + t + "]").children(".layui-tab-title").find('>li[lay-id="' + i + '"]');
            return C.tabClick.call(t[0], null, null, t), this
        }, i.prototype.tab = function(a) {
            a = a || {}, e.on("click", a.headerElem, function(t) {
                var i = u(this).index();
                C.tabClick.call(this, t, i, null, a)
            })
        }, i.prototype.progress = function(t, i) {
            var a = "layui-progress",
                t = u("." + a + "[lay-filter=" + t + "]").find("." + a + "-bar"),
                a = t.find("." + a + "-text");
            return t.css("width", function() {
                return /^.+\/.+$/.test(i) ? 100 * new Function("return " + i)() + "%" : i
            }).attr("lay-percent", i), a.text(i), this
        }, ".layui-nav"),
        f = "layui-nav-item",
        l = "layui-nav-bar",
        p = "layui-nav-tree",
        b = "layui-nav-child",
        v = "layui-nav-more",
        m = "layui-anim layui-anim-upbit",
        C = {
            tabClick: function(t, i, a, e) {
                e = e || {};
                var a = a || u(this),
                    i = i || a.parent().children("li").index(a),
                    l = e.headerElem ? a.parent() : a.parents(".layui-tab").eq(0),
                    e = e.bodyElem ? u(e.bodyElem) : l.children(".layui-tab-content").children(".layui-tab-item"),
                    n = a.find("a"),
                    n = "javascript:;" !== n.attr("href") && "_blank" === n.attr("target"),
                    s = "string" == typeof a.attr("lay-unselect"),
                    o = l.attr("lay-filter");
                n || s || (a.addClass(r).siblings().removeClass(r), e.eq(i).addClass(y).siblings().removeClass(y)), layui.event.call(this, c, "tab(" + o + ")", {
                    elem: l,
                    index: i
                })
            },
            tabDelete: function(t, i) {
                var i = i || u(this).parent(),
                    a = i.index(),
                    e = i.parents(".layui-tab").eq(0),
                    l = e.children(".layui-tab-content").children(".layui-tab-item"),
                    n = e.attr("lay-filter");
                i.hasClass(r) && (i.next()[0] && i.next().is("li") ? C.tabClick.call(i.next()[0], null, a + 1) : i.prev()[0] && i.prev().is("li") && C.tabClick.call(i.prev()[0], null, a - 1)), i.remove(), l.eq(a).remove(), setTimeout(function() {
                    C.tabAuto()
                }, 50), layui.event.call(this, c, "tabDelete(" + n + ")", {
                    elem: e,
                    index: a
                })
            },
            tabAuto: function() {
                var e = "layui-tab-bar",
                    l = "layui-tab-close",
                    n = this;
                u(".layui-tab").each(function() {
                    var t = u(this),
                        i = t.children(".layui-tab-title"),
                        a = (t.children(".layui-tab-content").children(".layui-tab-item"), 'lay-stope="tabmore"'),
                        a = u('<span class="layui-unselect layui-tab-bar" ' + a + "><i " + a + ' class="layui-icon">&#xe61a;</i></span>');
                    n === window && 8 != d.ie && C.hideTabMore(!0), t.attr("lay-allowClose") && i.find("li").each(function() {
                        var t, i = u(this);
                        i.find("." + l)[0] || ((t = u('<i class="layui-icon layui-icon-close layui-unselect ' + l + '"></i>')).on("click", C.tabDelete), i.append(t))
                    }), "string" != typeof t.attr("lay-unauto") && (i.prop("scrollWidth") > i.outerWidth() + 1 ? i.find("." + e)[0] || (i.append(a), t.attr("overflow", ""), a.on("click", function(t) {
                        i[this.title ? "removeClass" : "addClass"]("layui-tab-more"), this.title = this.title ? "" : "\u6536\u7f29"
                    })) : (i.find("." + e).remove(), t.removeAttr("overflow")))
                })
            },
            hideTabMore: function(t) {
                var i = u(".layui-tab-title");
                !0 !== t && "tabmore" === u(t.target).attr("lay-stope") || (i.removeClass("layui-tab-more"), i.find(".layui-tab-bar").attr("title", ""))
            },
            clickThis: function() {
                var t = u(this),
                    i = t.parents(h),
                    a = i.attr("lay-filter"),
                    e = t.parent(),
                    l = t.siblings("." + b),
                    n = "string" == typeof e.attr("lay-unselect");
                "javascript:;" !== t.attr("href") && "_blank" === t.attr("target") || n || l[0] || (i.find("." + r).removeClass(r), e.addClass(r)), i.hasClass(p) && (l.removeClass(m), l[0] && (e["none" === l.css("display") ? "addClass" : "removeClass"](f + "ed"), "all" === i.attr("lay-shrink") && e.siblings().removeClass(f + "ed"))), layui.event.call(this, c, "nav(" + a + ")", t)
            },
            collapse: function() {
                var t = u(this),
                    i = t.find(".layui-colla-icon"),
                    a = t.siblings(".layui-colla-content"),
                    e = t.parents(".layui-collapse").eq(0),
                    l = e.attr("lay-filter"),
                    n = "none" === a.css("display");
                "string" == typeof e.attr("lay-accordion") && ((e = e.children(".layui-colla-item").children("." + y)).siblings(".layui-colla-title").children(".layui-colla-icon").html("&#xe602;"), e.removeClass(y)), a[n ? "addClass" : "removeClass"](y), i.html(n ? "&#xe61a;" : "&#xe602;"), layui.event.call(this, c, "collapse(" + l + ")", {
                    title: t,
                    content: a,
                    show: n
                })
            }
        },
        a = (i.prototype.render = i.prototype.init = function(t, i) {
            var a = i ? '[lay-filter="' + i + '"]' : "",
                i = {
                    tab: function() {
                        C.tabAuto.call({})
                    },
                    nav: function() {
                        var s = {},
                            o = {},
                            c = {},
                            r = "layui-nav-title";
                        u(h + a).each(function(t) {
                            var i = u(this),
                                a = u('<span class="' + l + '"></span>'),
                                e = i.find("." + f);
                            i.find("." + l)[0] || (i.append(a), (i.hasClass(p) ? e.find("dd,>." + r) : e).on("mouseenter", function() {
                                !
                                function(t, i, a) {
                                    var e, l = u(this),
                                        n = l.find("." + b);
                                    i.hasClass(p) ? n[0] || (e = l.children("." + r), t.css({
                                        top: l.offset().top - i.offset().top,
                                        height: (e[0] ? e : l).outerHeight(),
                                        opacity: 1
                                    })) : (n.addClass(m), n.hasClass("layui-nav-child-c") && n.css({
                                        left: -(n.outerWidth() - l.width()) / 2
                                    }), n[0] ? t.css({
                                        left: t.position().left + t.width() / 2,
                                        width: 0,
                                        opacity: 0
                                    }) : t.css({
                                        left: l.position().left + parseFloat(l.css("marginLeft")),
                                        top: l.position().top + l.height() - t.height()
                                    }), s[a] = setTimeout(function() {
                                        t.css({
                                            width: n[0] ? 0 : l.width(),
                                            opacity: n[0] ? 0 : 1
                                        })
                                    }, d.ie && d.ie < 10 ? 0 : 200), clearTimeout(c[a]), "block" === n.css("display") && clearTimeout(o[a]), o[a] = setTimeout(function() {
                                        n.addClass(y), l.find("." + v).addClass(v + "d")
                                    }, 300))
                                }.call(this, a, i, t)
                            }).on("mouseleave", function() {
                                i.hasClass(p) ? a.css({
                                    height: 0,
                                    opacity: 0
                                }) : (clearTimeout(o[t]), o[t] = setTimeout(function() {
                                    i.find("." + b).removeClass(y), i.find("." + v).removeClass(v + "d")
                                }, 300))
                            }), i.on("mouseleave", function() {
                                clearTimeout(s[t]), c[t] = setTimeout(function() {
                                    i.hasClass(p) || a.css({
                                        width: 0,
                                        left: a.position().left + a.width() / 2,
                                        opacity: 0
                                    })
                                }, 200)
                            })), e.find("a").each(function() {
                                var t = u(this);
                                t.parent();
                                t.siblings("." + b)[0] && !t.children("." + v)[0] && t.append('<i class="layui-icon layui-icon-down ' + v + '"></i>'), t.off("click", C.clickThis).on("click", C.clickThis)
                            })
                        })
                    },
                    breadcrumb: function() {
                        u(".layui-breadcrumb" + a).each(function() {
                            var t = u(this),
                                i = "lay-separator",
                                a = t.attr(i) || "/",
                                e = t.find("a");
                            e.next("span[" + i + "]")[0] || (e.each(function(t) {
                                t !== e.length - 1 && u(this).after("<span " + i + ">" + a + "</span>")
                            }), t.css("visibility", "visible"))
                        })
                    },
                    progress: function() {
                        var e = "layui-progress";
                        u("." + e + a).each(function() {
                            var t = u(this),
                                i = t.find(".layui-progress-bar"),
                                a = i.attr("lay-percent");
                            i.css("width", function() {
                                return /^.+\/.+$/.test(a) ? 100 * new Function("return " + a)() + "%" : a
                            }), t.attr("lay-showPercent") && setTimeout(function() {
                                i.html('<span class="' + e + '-text">' + a + "</span>")
                            }, 350)
                        })
                    },
                    collapse: function() {
                        u(".layui-collapse" + a).each(function() {
                            u(this).find(".layui-colla-item").each(function() {
                                var t = u(this),
                                    i = t.find(".layui-colla-title"),
                                    t = "none" === t.find(".layui-colla-content").css("display");
                                i.find(".layui-colla-icon").remove(), i.append('<i class="layui-icon layui-colla-icon">' + (t ? "&#xe602;" : "&#xe61a;") + "</i>"), i.off("click", C.collapse).on("click", C.collapse)
                            })
                        })
                    }
                };
            return i[t] ? i[t]() : layui.each(i, function(t, i) {
                i()
            })
        }, new i),
        e = u(document);
    u(function() {
        a.render()
    });
    e.on("click", ".layui-tab-title li", C.tabClick), e.on("click", C.hideTabMore), u(window).on("resize", C.tabAuto), t(c, a)
});
layui.define("layer", function(e) {
    "use strict";
    var v = layui.$,
        t = layui.layer,
        r = layui.hint(),
        y = layui.device(),
        i = {
            config: {},
            set: function(e) {
                var t = this;
                return t.config = v.extend({}, t.config, e), t
            },
            on: function(e, t) {
                return layui.onevent.call(this, n, e, t)
            }
        },
        n = "upload",
        o = "layui-upload-file",
        a = "layui-upload-form",
        F = "layui-upload-iframe",
        b = "layui-upload-choose",
        x = function(e) {
            var t = this;
            t.config = v.extend({}, t.config, i.config, e), t.render()
        };
    x.prototype.config = {
        accept: "images",
        exts: "",
        auto: !0,
        bindAction: "",
        url: "",
        force: "",
        field: "file",
        acceptMime: "",
        method: "post",
        data: {},
        drag: !0,
        size: 0,
        number: 0,
        multiple: !1
    }, x.prototype.render = function(e) {
        var t = this;
        (e = t.config).elem = v(e.elem), e.bindAction = v(e.bindAction), t.file(), t.events()
    }, x.prototype.file = function() {
        var e = this,
            t = e.config,
            i = e.elemFile = v(['<input class="' + o + '" type="file" accept="' + t.acceptMime + '" name="' + t.field + '"', t.multiple ? " multiple" : "", ">"].join("")),
            n = t.elem.next();
        (n.hasClass(o) || n.hasClass(a)) && n.remove(), y.ie && y.ie < 10 && t.elem.wrap('<div class="layui-upload-wrap"></div>'), e.isFile() ? (e.elemFile = t.elem, t.field = t.elem[0].name) : t.elem.after(i), y.ie && y.ie < 10 && e.initIE()
    }, x.prototype.initIE = function() {
        var i, e = this.config,
            t = v('<iframe id="' + F + '" class="' + F + '" name="' + F + '" frameborder="0"></iframe>'),
            n = v(['<form target="' + F + '" class="' + a + '" method="post" key="set-mine" enctype="multipart/form-data" action="' + e.url + '">', "</form>"].join(""));
        v("#" + F)[0] || v("body").append(t), e.elem.next().hasClass(a) || (this.elemFile.wrap(n), e.elem.next("." + a).append((i = [], layui.each(e.data, function(e, t) {
            t = "function" == typeof t ? t() : t, i.push('<input type="hidden" name="' + e + '" value="' + t + '">')
        }), i.join(""))))
    }, x.prototype.msg = function(e) {
        return t.msg(e, {
            icon: 2,
            shift: 6
        })
    }, x.prototype.isFile = function() {
        var e = this.config.elem[0];
        if (e) return "input" === e.tagName.toLocaleLowerCase() && "file" === e.type
    }, x.prototype.preview = function(n) {
        window.FileReader && layui.each(this.chooseFiles, function(e, t) {
            var i = new FileReader;
            i.readAsDataURL(t), i.onload = function() {
                n && n(e, t, this.result)
            }
        })
    }, x.prototype.upload = function(i, e) {
        var n, o, t, a, l = this,
            r = l.config,
            u = l.elemFile[0],
            c = function() {
                var t = 0,
                    o = 0,
                    e = i || l.files || l.chooseFiles || u.files,
                    a = function() {
                        r.multiple && t + o === l.fileLength && "function" == typeof r.allDone && r.allDone({
                            total: l.fileLength,
                            successful: t,
                            failed: o
                        })
                    };
                layui.each(e, function(i, e) {
                    var n = new FormData,
                        e = (n.append(r.field, e), layui.each(r.data, function(e, t) {
                            t = "function" == typeof t ? t() : t, n.append(e, t)
                        }), {
                            url: r.url,
                            type: "post",
                            data: n,
                            contentType: !1,
                            processData: !1,
                            dataType: "json",
                            headers: r.headers || {},
                            success: function(e) {
                                t++, f(i, e), a()
                            },
                            error: function(e) {
                                o++, l.msg("Request URL is abnormal: " + (e.statusText || "error")), p(i), a()
                            }
                        });
                    "function" == typeof r.progress && (e.xhr = function() {
                        var e = v.ajaxSettings.xhr();
                        return e.upload.addEventListener("progress", function(e) {
                            var t;
                            e.lengthComputable && (t = Math.floor(e.loaded / e.total * 100), r.progress(t, (r.item || r.elem)[0], e, i))
                        }), e
                    }), v.ajax(e)
                })
            },
            s = function() {
                var n = v("#" + F);
                l.elemFile.parent().submit(), clearInterval(x.timer), x.timer = setInterval(function() {
                    var e, t = n.contents().find("body");
                    try {
                        e = t.text()
                    } catch (i) {
                        l.msg("Cross-domain requests are not supported"), clearInterval(x.timer), p()
                    }
                    e && (clearInterval(x.timer), t.html(""), f(0, e))
                }, 30)
            },
            f = function(e, t) {
                if (l.elemFile.next("." + b).remove(), u.value = "", "json" === r.force && "object" != typeof t) try {
                    t = JSON.parse(t)
                } catch (i) {
                    return t = {}, l.msg("Please return JSON data format")
                }
                "function" == typeof r.done && r.done(t, e || 0, function(e) {
                    l.upload(e)
                })
            },
            p = function(e) {
                r.auto && (u.value = ""), "function" == typeof r.error && r.error(e || 0, function(e) {
                    l.upload(e)
                })
            },
            d = r.exts,
            m = (o = [], layui.each(i || l.chooseFiles, function(e, t) {
                o.push(t.name)
            }), o),
            h = {
                preview: function(e) {
                    l.preview(e)
                },
                upload: function(e, t) {
                    var i = {};
                    i[e] = t, l.upload(i)
                },
                pushFile: function() {
                    return l.files = l.files || {}, layui.each(l.chooseFiles, function(e, t) {
                        l.files[e] = t
                    }), l.files
                },
                resetFile: function(e, t, i) {
                    t = new File([t], i);
                    l.files = l.files || {}, l.files[e] = t
                }
            },
            g = {
                file: "\u6587\u4ef6",
                images: "\u56fe\u7247",
                video: "\u89c6\u9891",
                audio: "\u97f3\u9891"
            }[r.accept] || "\u6587\u4ef6",
            m = 0 === m.length ? u.value.match(/[^\/\\]+\..+/g) || [] || "" : m;
        if (0 !== m.length) {
            switch (r.accept) {
            case "file":
                layui.each(m, function(e, t) {
                    if (d && !RegExp(".\\.(" + d + ")$", "i").test(escape(t))) return n = !0
                });
                break;
            case "video":
                layui.each(m, function(e, t) {
                    if (!RegExp(".\\.(" + (d || "avi|mp4|wma|rmvb|rm|flash|3gp|flv") + ")$", "i").test(escape(t))) return n = !0
                });
                break;
            case "audio":
                layui.each(m, function(e, t) {
                    if (!RegExp(".\\.(" + (d || "mp3|wav|mid") + ")$", "i").test(escape(t))) return n = !0
                });
                break;
            default:
                layui.each(m, function(e, t) {
                    if (!RegExp(".\\.(" + (d || "jpg|png|gif|bmp|jpeg") + ")$", "i").test(escape(t))) return n = !0
                })
            }
            if (n) return l.msg("\u9009\u62e9\u7684" + g + "\u4e2d\u5305\u542b\u4e0d\u652f\u6301\u7684\u683c\u5f0f"), u.value = "";
            if ("choose" !== e && !r.auto || (r.choose && r.choose(h), "choose" !== e)) {
                if (l.fileLength = (t = 0, g = i || l.files || l.chooseFiles || u.files, layui.each(g, function() {
                    t++
                }), t), r.number && l.fileLength > r.number) return l.msg("\u540c\u65f6\u6700\u591a\u53ea\u80fd\u4e0a\u4f20: " + r.number + " \u4e2a\u6587\u4ef6<br>\u60a8\u5f53\u524d\u5df2\u7ecf\u9009\u62e9\u4e86: " + l.fileLength + " \u4e2a\u6587\u4ef6");
                if (0 < r.size && !(y.ie && y.ie < 10)) if (layui.each(l.chooseFiles, function(e, t) {
                    t.size > 1024 * r.size && (t = 1 <= (t = r.size / 1024) ? t.toFixed(2) + "MB" : r.size + "KB", u.value = "", a = t)
                }), a) return l.msg("\u6587\u4ef6\u5927\u5c0f\u4e0d\u80fd\u8d85\u8fc7 " + a);
                if (!r.before || !1 !== r.before(h)) y.ie ? (9 < y.ie ? c : s)() : c()
            }
        }
    }, x.prototype.reload = function(e) {
        delete(e = e || {}).elem, delete e.bindAction;
        (e = this.config = v.extend({}, this.config, i.config, e)).elem.next().attr({
            name: e.name,
            accept: e.acceptMime,
            multiple: e.multiple
        })
    }, x.prototype.events = function() {
        var n = this,
            o = n.config,
            a = function(e) {
                n.chooseFiles = {}, layui.each(e, function(e, t) {
                    var i = (new Date).getTime();
                    n.chooseFiles[i + "-" + e] = t
                })
            },
            l = function(e, t) {
                var i = n.elemFile,
                    e = (o.item || o.elem, 1 < e.length ? e.length + "\u4e2a\u6587\u4ef6" : (e[0] || {}).name || i[0].value.match(/[^\/\\]+\..+/g) || [] || "");
                i.next().hasClass(b) && i.next().remove(), n.upload(null, "choose"), n.isFile() || o.choose || i.after('<span class="layui-inline ' + b + '">' + e + "</span>")
            };
        o.elem.off("upload.start").on("upload.start", function() {
            var e = v(this),
                t = e.attr("lay-data");
            if (t) try {
                t = new Function("return " + t)(), n.config = v.extend({}, o, t)
            } catch (i) {
                r.error("Upload element property lay-data configuration item has a syntax error: " + t)
            }
            n.config.item = e, n.elemFile[0].click()
        }), y.ie && y.ie < 10 || o.elem.off("upload.over").on("upload.over", function() {
            v(this).attr("lay-over", "")
        }).off("upload.leave").on("upload.leave", function() {
            v(this).removeAttr("lay-over")
        }).off("upload.drop").on("upload.drop", function(e, t) {
            var i = v(this),
                t = t.originalEvent.dataTransfer.files || [];
            i.removeAttr("lay-over"), a(t), o.auto ? n.upload() : l(t)
        }), n.elemFile.off("upload.change").on("upload.change", function() {
            var e = this.files || [];
            a(e), o.auto ? n.upload() : l(e)
        }), o.bindAction.off("upload.action").on("upload.action", function() {
            n.upload()
        }), o.elem.data("haveEvents") || (n.elemFile.on("change", function() {
            v(this).trigger("upload.change")
        }), o.elem.on("click", function() {
            n.isFile() || v(this).trigger("upload.start")
        }), o.drag && o.elem.on("dragover", function(e) {
            e.preventDefault(), v(this).trigger("upload.over")
        }).on("dragleave", function(e) {
            v(this).trigger("upload.leave")
        }).on("drop", function(e) {
            e.preventDefault(), v(this).trigger("upload.drop", e)
        }), o.bindAction.on("click", function() {
            v(this).trigger("upload.action")
        }), o.elem.data("haveEvents", !0))
    }, i.render = function(e) {
        e = new x(e);
        return function() {
            var t = this;
            return {
                upload: function(e) {
                    t.upload.call(t, e)
                },
                reload: function(e) {
                    t.reload.call(t, e)
                },
                config: t.config
            }
        }.call(e)
    }, e(n, i)
});
layui.define(["layer", "util"], function(e) {
    "use strict";
    var C = layui.$,
        h = layui.layer,
        d = layui.util,
        l = layui.hint(),
        w = (layui.device(), "form"),
        o = ".layui-form",
        T = "layui-this",
        $ = "layui-hide",
        F = "layui-disabled",
        t = function() {
            this.config = {
                verify: {
                    required: [/[\S]+/, "\u5fc5\u586b\u9879\u4e0d\u80fd\u4e3a\u7a7a"],
                    phone: [/^1\d{10}$/, "\u8bf7\u8f93\u5165\u6b63\u786e\u7684\u624b\u673a\u53f7"],
                    email: [/^([a-zA-Z0-9_\.\-])+\@(([a-zA-Z0-9\-])+\.)+([a-zA-Z0-9]{2,4})+$/, "\u90ae\u7bb1\u683c\u5f0f\u4e0d\u6b63\u786e"],
                    url: [/^(#|(http(s?)):\/\/|\/\/)[^\s]+\.[^\s]+$/, "\u94fe\u63a5\u683c\u5f0f\u4e0d\u6b63\u786e"],
                    number: function(e) {
                        if (!e || isNaN(e)) return "\u53ea\u80fd\u586b\u5199\u6570\u5b57"
                    },
                    date: [/^(\d{4})[-\/](\d{1}|0\d{1}|1[0-2])([-\/](\d{1}|0\d{1}|[1-2][0-9]|3[0-1]))*$/, "\u65e5\u671f\u683c\u5f0f\u4e0d\u6b63\u786e"],
                    identity: [/(^\d{15}$)|(^\d{17}(x|X|\d)$)/, "\u8bf7\u8f93\u5165\u6b63\u786e\u7684\u8eab\u4efd\u8bc1\u53f7"]
                },
                autocomplete: null
            }
        },
        i = (t.prototype.set = function(e) {
            return C.extend(!0, this.config, e), this
        }, t.prototype.verify = function(e) {
            return C.extend(!0, this.config.verify, e), this
        }, t.prototype.getFormElem = function(e) {
            return C(o + (e ? '[lay-filter="' + e + '"]' : ""))
        }, t.prototype.on = function(e, t) {
            return layui.onevent.call(this, w, e, t)
        }, t.prototype.val = function(e, i) {
            return this.getFormElem(e).each(function(e, t) {
                var a = C(this);
                layui.each(i, function(e, t) {
                    var i, e = a.find('[name="' + e + '"]');
                    e[0] && ("checkbox" === (i = e[0].type) ? e[0].checked = t : "radio" === i ? e.each(function() {
                        this.value == t && (this.checked = !0)
                    }) : e.val(t))
                })
            }), r.render(null, e), this.getValue(e)
        }, t.prototype.getValue = function(e, t) {
            t = t || this.getFormElem(e);
            var a = {},
                n = {},
                e = t.find("input,select,textarea");
            return layui.each(e, function(e, t) {
                var i;
                C(this);
                t.name = (t.name || "").replace(/^\s*|\s*&/, ""), t.name && (/^.*\[\]$/.test(t.name) && (i = t.name.match(/^(.*)\[\]$/g)[0], a[i] = 0 | a[i], i = t.name.replace(/^(.*)\[\]$/, "$1[" + a[i]+++"]")), /^checkbox|radio$/.test(t.type) && !t.checked || (n[i || t.name] = t.value))
            }), n
        }, t.prototype.render = function(e, t) {
            var i = this.config,
                a = C(o + (t ? '[lay-filter="' + t + '"]' : "")),
                n = {
                    input: function(e) {
                        e = e || a.find("input,textarea");
                        i.autocomplete && e.attr("autocomplete", i.autocomplete), a.find("input[lay-affix],textarea[lay-affix]").each(function() {
                            var i = C(this),
                                t = i.attr("lay-affix"),
                                a = i.next(".layui-input-suffix"),
                                n = function(e, t) {
                                    e && e[C.trim(t) ? "removeClass" : "addClass"]($)
                                },
                                l = function(e) {
                                    a.remove(), a = C(['<div class="layui-input-suffix layui-input-affix-event">', '<i class="layui-icon layui-icon-' + e + '"></i>', "</div>"].join("")), i.after(a), n(a, i.val()), i.on("input propertychange", function() {
                                        var e = this.value;
                                        n(a, e)
                                    }), a.on("click", function() {
                                        var e = i.attr("lay-filter");
                                        r[t] && r[t][1].call(this), layui.event.call(this, w, "input-affix(" + e + ")", {
                                            elem: i[0],
                                            affix: t
                                        })
                                    })
                                },
                                r = {
                                    clear: [function() {
                                        l("clear")
                                    }, function() {
                                        i.val("").focus(), n(a, null)
                                    }],
                                    eye: [function() {
                                        l("eye")
                                    }, function() {
                                        var e = "LAY_FORM_INPUT_AFFIX_SHOW",
                                            t = i.data(e);
                                        i.attr("type", t ? "password" : "text").data(e, !t), l(t ? "eye" : "eye-invisible")
                                    }]
                                };
                            r[t] && r[t][0]()
                        })
                    },
                    select: function(e) {
                        var p, c = "\u8bf7\u9009\u62e9",
                            m = "layui-form-select",
                            g = "layui-select-title",
                            x = "layui-select-none",
                            k = "",
                            e = e || a.find("select"),
                            b = function(e, t) {
                                C(e.target).parent().hasClass(g) && !t || (C("." + m).removeClass(m + "ed " + m + "up"), p && k && p.val(k)), p = null
                            },
                            u = function(a, e, t) {
                                var s, r, i, n, o, l, c = C(this),
                                    u = a.find("." + g),
                                    d = u.find("input"),
                                    f = a.find("dl"),
                                    h = f.children("dd"),
                                    y = f.children("dt"),
                                    v = this.selectedIndex;
                                e || (r = c.attr("lay-search"), i = function() {
                                    var e = a.offset().top + a.outerHeight() + 5 - E.scrollTop(),
                                        t = f.outerHeight();
                                    v = c[0].selectedIndex, a.addClass(m + "ed"), h.removeClass($), y.removeClass($), s = null, h.eq(v).addClass(T).siblings().removeClass(T), e + t > E.height() && t <= e && a.addClass(m + "up"), o()
                                }, n = function(e) {
                                    a.removeClass(m + "ed " + m + "up"), d.blur(), s = null, e || l(d.val(), function(e) {
                                        var t = c[0].selectedIndex;
                                        e && (k = C(c[0].options[t]).html(), 0 === t && k === d.attr("placeholder") && (k = ""), d.val(k || ""))
                                    })
                                }, o = function() {
                                    var e, t, i = f.children("dd." + T);
                                    i[0] && (e = i.position().top, t = f.height(), i = i.height(), t < e && f.scrollTop(e + f.scrollTop() - t + i - 5), e < 0 && f.scrollTop(e + f.scrollTop() - 5))
                                }, u.on("click", function(e) {
                                    a.hasClass(m + "ed") ? n() : (b(e, !0), i()), f.find("." + x).remove()
                                }), u.find(".layui-edge").on("click", function() {
                                    d.focus()
                                }), d.on("keyup", function(e) {
                                    9 === e.keyCode && i()
                                }).on("keydown", function(l) {
                                    var e = l.keyCode,
                                        r = (9 === e && n(), function(a, n) {
                                            l.preventDefault();
                                            var e = function() {
                                                    var e = f.children("dd." + T);
                                                    if (f.children("dd." + $)[0] && "next" === a) {
                                                        var t = f.children("dd:not(." + $ + ",." + F + ")"),
                                                            i = t.eq(0).index();
                                                        if (0 <= i && i < e.index() && !t.hasClass(T)) return t.eq(0).prev()[0] ? t.eq(0).prev() : f.children(":last")
                                                    }
                                                    return n && n[0] ? n : s && s[0] ? s : e
                                                }(),
                                                t = e[a](),
                                                i = e[a]("dd:not(." + $ + ")");
                                            return t[0] ? (s = e[a](), i[0] && !i.hasClass(F) || !s[0] ? (i.addClass(T).siblings().removeClass(T), void o()) : r(a, s)) : s = null
                                        });
                                    38 === e && r("prev"), 40 === e && r("next"), 13 === e && (l.preventDefault(), f.children("dd." + T).trigger("click"))
                                }), l = function(a, e, n) {
                                    var l = 0,
                                        t = (layui.each(h, function() {
                                            var e = C(this),
                                                t = e.text(),
                                                i = ("cs" !== r && (t = t.toLowerCase(), a = a.toLowerCase()), -1 === t.indexOf(a));
                                            ("" === a || "blur" === n ? a !== t : i) && l++, "keyup" === n && e[i ? "addClass" : "removeClass"]($)
                                        }), "keyup" === n && layui.each(y, function() {
                                            var e = C(this),
                                                t = e.nextUntil("dt").filter("dd");
                                            e[t.length == t.filter("." + $).length ? "addClass" : "removeClass"]($)
                                        }), l === h.length);
                                    return e(t), t
                                }, t && d.on("keyup", function(e) {
                                    var t = this.value,
                                        e = e.keyCode;
                                    if (9 === e || 13 === e || 37 === e || 38 === e || 39 === e || 40 === e) return !1;
                                    l(t, function(e) {
                                        e ? f.find("." + x)[0] || f.append('<p class="' + x + '">\u65e0\u5339\u914d\u9879</p>') : f.find("." + x).remove()
                                    }, "keyup"), "" === t && f.find("." + x).remove(), o()
                                }).on("blur", function(e) {
                                    var t = c[0].selectedIndex;
                                    p = d, k = C(c[0].options[t]).html(), 0 === t && k === d.attr("placeholder") && (k = ""), setTimeout(function() {
                                        l(d.val(), function(e) {
                                            k || d.val("")
                                        }, "blur")
                                    }, 200)
                                }), h.on("click", function() {
                                    var e = C(this),
                                        t = e.attr("lay-value"),
                                        i = c.attr("lay-filter");
                                    return e.hasClass(F) || (e.hasClass("layui-select-tips") ? d.val("") : (d.val(e.text()), e.addClass(T)), e.siblings().removeClass(T), c.val(t).removeClass("layui-form-danger"), layui.event.call(this, w, "select(" + i + ")", {
                                        elem: c[0],
                                        value: t,
                                        othis: a
                                    }), n(!0)), !1
                                }), a.find("dl>dt").on("click", function(e) {
                                    return !1
                                }), C(document).off("click", b).on("click", b))
                            };
                        e.each(function(e, t) {
                            var i = C(this),
                                a = i.next("." + m),
                                n = this.disabled,
                                l = t.value,
                                r = C(t.options[t.selectedIndex]),
                                t = t.options[0];
                            if ("string" == typeof i.attr("lay-ignore")) return i.show();
                            var s, o = "string" == typeof i.attr("lay-search"),
                                t = t && !t.value && t.innerHTML || c,
                                r = C(['<div class="' + (o ? "" : "layui-unselect ") + m, (n ? " layui-select-disabled" : "") + '">', '<div class="' + g + '">', '<input type="text" placeholder="' + d.escape(C.trim(t)) + '" value="' + d.escape(C.trim(l ? r.html() : "")) + '"' + (!n && o ? "" : " readonly") + ' class="layui-input' + (o ? "" : " layui-unselect") + (n ? " " + F : "") + '">', '<i class="layui-edge"></i></div>', '<dl class="layui-anim layui-anim-upbit' + (i.find("optgroup")[0] ? " layui-select-group" : "") + '">', (t = i.find("*"), s = [], layui.each(t, function(e, t) {
                                    var i = t.tagName.toLowerCase();
                                    0 !== e || t.value || "optgroup" === i ? "optgroup" === i ? s.push("<dt>" + t.label + "</dt>") : s.push('<dd lay-value="' + d.escape(t.value) + '" class="' + (l === t.value ? T : "") + (t.disabled ? " " + F : "") + '">' + C.trim(t.innerHTML) + "</dd>") : s.push('<dd lay-value="" class="layui-select-tips">' + C.trim(t.innerHTML || c) + "</dd>")
                                }), 0 === s.length && s.push('<dd lay-value="" class="' + F + '">\u6ca1\u6709\u9009\u9879</dd>'), s.join("") + "</dl>"), "</div>"].join(""));
                            a[0] && a.remove(), i.after(r), u.call(this, r, n, o)
                        })
                    },
                    checkbox: function(e) {
                        var o = {
                            checkbox: ["layui-form-checkbox", "layui-form-checked", "checkbox"],
                            _switch: ["layui-form-switch", "layui-form-onswitch", "switch"]
                        },
                            e = e || a.find("input[type=checkbox]");
                        e.each(function(e, t) {
                            var i = C(this),
                                a = i.attr("lay-skin"),
                                n = (i.attr("lay-text") || "").split("|"),
                                l = this.disabled,
                                r = o[a = "switch" === a ? "_" + a : a] || o.checkbox;
                            if ("string" == typeof i.attr("lay-ignore")) return i.show();
                            var s = i.next("." + r[0]),
                                t = C(['<div class="layui-unselect ' + r[0], t.checked ? " " + r[1] : "", l ? " layui-checkbox-disabled " + F : "", '"', a ? ' lay-skin="' + a + '"' : "", ">", (l = {
                                    checkbox: [t.title.replace(/\s/g, "") ? "<span>" + d.escape(t.title) + "</span>" : "", '<i class="layui-icon layui-icon-ok"></i>'].join(""),
                                    _switch: "<em>" + ((t.checked ? n[0] : n[1]) || "") + "</em><i></i>"
                                })[a] || l.checkbox, "</div>"].join(""));
                            s[0] && s.remove(), i.after(t), function(i, a) {
                                var n = C(this);
                                i.on("click", function() {
                                    var e = n.attr("lay-filter"),
                                        t = (n.attr("lay-text") || "").split("|");
                                    n[0].disabled || (n[0].checked ? (n[0].checked = !1, i.removeClass(a[1]).find("em").text(t[1])) : (n[0].checked = !0, i.addClass(a[1]).find("em").text(t[0])), layui.event.call(n[0], w, a[2] + "(" + e + ")", {
                                        elem: n[0],
                                        value: n[0].value,
                                        othis: i
                                    }))
                                })
                            }.call(this, t, r)
                        })
                    },
                    radio: function(e) {
                        var r = "layui-form-radio",
                            s = ["&#xe643;", "&#xe63f;"],
                            e = e || a.find("input[type=radio]");
                        e.each(function(e, t) {
                            var i = C(this),
                                a = i.next("." + r),
                                n = this.disabled;
                            if ("string" == typeof i.attr("lay-ignore")) return i.show();
                            a[0] && a.remove();
                            n = C(['<div class="layui-unselect ' + r, t.checked ? " " + r + "ed" : "", (n ? " layui-radio-disabled " + F : "") + '">', '<i class="layui-anim layui-icon">' + s[t.checked ? 0 : 1] + "</i>", "<div>" + (a = d.escape(t.title || ""), a = "string" == typeof i.next().attr("lay-radio") ? i.next().html() : a) + "</div>", "</div>"].join(""));
                            i.after(n), function(a) {
                                var n = C(this),
                                    l = "layui-anim-scaleSpring";
                                a.on("click", function() {
                                    var e = n[0].name,
                                        t = n.parents(o),
                                        i = n.attr("lay-filter"),
                                        e = t.find("input[name=" + e.replace(/(\.|#|\[|\])/g, "\\$1") + "]");
                                    n[0].disabled || (layui.each(e, function() {
                                        var e = C(this).next("." + r);
                                        this.checked = !1, e.removeClass(r + "ed"), e.find(".layui-icon").removeClass(l).html(s[1])
                                    }), n[0].checked = !0, a.addClass(r + "ed"), a.find(".layui-icon").addClass(l).html(s[0]), layui.event.call(n[0], w, "radio(" + i + ")", {
                                        elem: n[0],
                                        value: n[0].value,
                                        othis: a
                                    }))
                                })
                            }.call(this, n)
                        })
                    }
                };
            return "object" === layui.type(e) ? e.each(function(e, t) {
                var i = C(t);
                i.closest(o).length && ("SELECT" === t.tagName ? n.select(i) : "INPUT" === t.tagName && ("checkbox" === (t = t.type) || "radio" === t ? n[t](i) : n.input(i)))
            }) : e ? n[e] ? n[e]() : l.error('\u4e0d\u652f\u6301\u7684 "' + e + '" \u8868\u5355\u6e32\u67d3') : layui.each(n, function(e, t) {
                t()
            }), this
        }, t.prototype.validate = function(e) {
            var u = null,
                d = r.config.verify,
                f = "layui-form-danger";
            return !(e = C(e))[0] || (e.attr("lay-verify") !== undefined || !1 !== this.validate(e.find("*[lay-verify]"))) && (layui.each(e, function(e, r) {
                var s = C(this),
                    t = (s.attr("lay-verify") || "").split("|"),
                    o = s.attr("lay-verType"),
                    c = s.val();
                if (s.removeClass(f), layui.each(t, function(e, t) {
                    var i = "",
                        a = d[t];
                    if (a) {
                        var n = "function" == typeof a ? i = a(c, r) : !a[0].test(c),
                            l = "select" === r.tagName.toLowerCase() || /^checkbox|radio$/.test(r.type),
                            i = i || a[1];
                        if ("required" === t && (i = s.attr("lay-reqText") || i), n) return "tips" === o ? h.tips(i, "string" != typeof s.attr("lay-ignore") && l ? s.next() : s, {
                            tips: 1
                        }) : "alert" === o ? h.alert(i, {
                            title: "\u63d0\u793a",
                            shadeClose: !0
                        }) : /\bstring|number\b/.test(typeof i) && h.msg(i, {
                            icon: 5,
                            shift: 6
                        }), setTimeout(function() {
                            (l ? s.next().find("input") : r).focus()
                        }, 7), s.addClass(f), u = !0
                    }
                }), u) return u
            }), !u)
        }, t.prototype.submit = function(e, t) {
            var i = C(this),
                e = "string" == typeof e ? e : i.attr("lay-filter"),
                a = this.getFormElem ? this.getFormElem(e) : i.parents(o).eq(0),
                n = a.find("*[lay-verify]");
            if (!r.validate(n)) return !1;
            n = r.getValue(null, a), a = {
                elem: this.getFormElem ? window.event && window.event.target : this,
                form: (this.getFormElem ? a : i.parents("form"))[0],
                field: n
            };
            return "function" == typeof t && t(a), layui.event.call(this, w, "submit(" + e + ")", a)
        }),
        r = new t,
        t = C(document),
        E = C(window);
    C(function() {
        r.render()
    }), t.on("reset", o, function() {
        var e = C(this).attr("lay-filter");
        setTimeout(function() {
            r.render(null, e)
        }, 50)
    }), t.on("submit", o, i).on("click", "*[lay-submit]", i), e(w, r)
});
layui.define(["lay", "laytpl", "laypage", "form", "util"], function(e) {
    "use strict";
    var v = layui.$,
        d = layui.lay,
        g = layui.laytpl,
        o = layui.laypage,
        b = layui.layer,
        h = layui.form,
        x = layui.util,
        p = layui.hint(),
        f = layui.device(),
        k = {
            config: {
                checkName: "LAY_CHECKED",
                indexName: "LAY_TABLE_INDEX",
                numbersName: "LAY_INDEX",
                disabledName: "LAY_DISABLED"
            },
            cache: {},
            index: layui.table ? layui.table.index + 1e4 : 0,
            set: function(e) {
                var t = this;
                return t.config = v.extend({}, t.config, e), t
            },
            on: function(e, t) {
                return layui.onevent.call(this, w, e, t)
            }
        },
        m = function() {
            var a = this,
                e = a.config,
                i = e.id || e.index;
            return i && (m.that[i] = a, m.config[i] = e), {
                config: e,
                reload: function(e, t) {
                    a.reload.call(a, e, t)
                },
                reloadData: function(e, t) {
                    k.reloadData(i, e, t)
                },
                setColsWidth: function() {
                    a.setColsWidth.call(a)
                },
                resize: function() {
                    a.resize.call(a)
                }
            }
        },
        l = function(e) {
            var t = m.config[e];
            return t || p.error(e ? "The table instance with ID '" + e + "' not found" : "ID argument required"), t || null
        },
        C = function(e) {
            var t = this.config || {},
                a = (e = e || {}).item3,
                i = e.content,
                t = (("escape" in a ? a : t).escape && (i = x.escape(i)), e.text && a.exportTemplet || a.templet || a.toolbar);
            return t && (i = "function" == typeof t ? t.call(a, e.tplData, e.obj) : g(v(t).html() || String(i)).render(v.extend({
                LAY_COL: a
            }, e.tplData))), e.text ? v("<div>" + i + "</div>").text() : i
        },
        w = "table",
        t = ".layui-table",
        T = "layui-hide",
        r = "layui-hide-v",
        c = "layui-none",
        L = "layui-table-view",
        s = ".layui-table-header",
        N = ".layui-table-body",
        D = ".layui-table-pageview",
        W = ".layui-table-sort",
        A = "layui-table-edit",
        E = "layui-table-hover",
        _ = "laytable-cell-group",
        j = "layui-table-col-special",
        M = "LAY_TABLE_MOVE_DICT",
        a = function(e) {
            return ['<table cellspacing="0" cellpadding="0" border="0" class="layui-table" ', '{{# if(d.data.skin){ }}lay-skin="{{=d.data.skin}}"{{# } }} {{# if(d.data.size){ }}lay-size="{{=d.data.size}}"{{# } }} {{# if(d.data.even){ }}lay-even{{# } }}>', "<thead>", "{{# layui.each(d.data.cols, function(i1, item1){ }}", "<tr>", "{{# layui.each(item1, function(i2, item2){ }}", '{{# if(item2.fixed && item2.fixed !== "right"){ left = true; } }}', '{{# if(item2.fixed === "right"){ right = true; } }}', (e = e || {}).fixed && "right" !== e.fixed ? '{{# if(item2.fixed && item2.fixed !== "right"){ }}' : "right" === e.fixed ? '{{# if(item2.fixed === "right"){ }}' : "", "{{# var isSort = !(item2.colGroup) && item2.sort; }}", '<th data-field="{{= item2.field||i2 }}" data-key="{{=d.index}}-{{=i1}}-{{=i2}}" {{# if( item2.parentKey){ }}data-parentkey="{{= item2.parentKey }}"{{# } }} {{# if(item2.minWidth){ }}data-minwidth="{{=item2.minWidth}}"{{# } }} {{# if(item2.maxWidth){ }}data-maxwidth="{{=item2.maxWidth}}"{{# } }} {{#if(item2.colspan){}} colspan="{{=item2.colspan}}"{{#} if(item2.rowspan){}} rowspan="{{=item2.rowspan}}"{{#}}} {{# if(item2.unresize || item2.colGroup){ }}data-unresize="true"{{# } }} class="{{# if(item2.hide){ }}layui-hide{{# } }}{{# if(isSort){ }} layui-unselect{{# } }}{{# if(!item2.field){ }} layui-table-col-special{{# } }}"{{# if(item2.title){ }} title="{{ layui.$(\'<div>\' + item2.title + \'</div>\').text() }}"{{# } }}>', '<div class="layui-table-cell laytable-cell-', "{{# if(item2.colGroup){ }}", "group", "{{# } else { }}", "{{=d.index}}-{{=i1}}-{{=i2}}", '{{# if(item2.type !== "normal"){ }}', " laytable-cell-{{= item2.type }}", "{{# } }}", "{{# } }}", '" {{#if(item2.align){}}align="{{=item2.align}}"{{#}}}>', '{{# if(item2.type === "checkbox"){ }}', '<input type="checkbox" name="layTableCheckbox" lay-skin="primary" lay-filter="layTableAllChoose" {{# if(item2[d.data.checkName]){ }}checked{{# }; }}>', "{{# } else { }}", '<span>{{-item2.title||""}}</span>', "{{# if(isSort){ }}", '<span class="layui-table-sort layui-inline"><i class="layui-edge layui-table-sort-asc" title="\u5347\u5e8f"></i><i class="layui-edge layui-table-sort-desc" title="\u964d\u5e8f"></i></span>', "{{# } }}", "{{# } }}", "</div>", "</th>", e.fixed ? "{{# }; }}" : "", "{{# }); }}", "</tr>", "{{# }); }}", "</thead>", "</table>"].join("")
        },
        i = ['<table cellspacing="0" cellpadding="0" border="0" class="layui-table" ', '{{# if(d.data.skin){ }}lay-skin="{{=d.data.skin}}"{{# } }} {{# if(d.data.size){ }}lay-size="{{=d.data.size}}"{{# } }} {{# if(d.data.even){ }}lay-even{{# } }}>', "<tbody></tbody>", "</table>"].join(""),
        u = [, "{{# if(d.data.toolbar){ }}", '<div class="layui-table-tool">', '<div class="layui-table-tool-temp"></div>', '<div class="layui-table-tool-self"></div>', "</div>", "{{# } }}", '<div class="layui-table-box">', "{{# if(d.data.loading){ }}", '<div class="layui-table-init" style="background-color: #fff;">', '<i class="layui-icon layui-icon-loading layui-anim layui-anim-rotate layui-anim-loop"></i>', "</div>", "{{# } }}", "{{# var left, right; }}", '<div class="layui-table-header">', a(), "</div>", '<div class="layui-table-body layui-table-main">', i, "</div>", "{{# if(left){ }}", '<div class="layui-table-fixed layui-table-fixed-l">', '<div class="layui-table-header">', a({
            fixed: !0
        }), "</div>", '<div class="layui-table-body">', i, "</div>", "</div>", "{{# }; }}", "{{# if(right){ }}", '<div class="layui-table-fixed layui-table-fixed-r layui-hide">', '<div class="layui-table-header">', a({
            fixed: "right"
        }), '<div class="layui-table-mend"></div>', "</div>", '<div class="layui-table-body">', i, "</div>", "</div>", "{{# }; }}", "</div>", "{{# if(d.data.totalRow){ }}", '<div class="layui-table-total">', '<table cellspacing="0" cellpadding="0" border="0" class="layui-table" ', '{{# if(d.data.skin){ }}lay-skin="{{=d.data.skin}}"{{# } }} {{# if(d.data.size){ }}lay-size="{{=d.data.size}}"{{# } }} {{# if(d.data.even){ }}lay-even{{# } }}>', '<tbody><tr><td><div class="layui-table-cell" style="visibility: hidden;">Total</div></td></tr></tbody>', "</table>", "</div>", "{{# } }}", '<div class="layui-table-column layui-table-page layui-hide">', '<div class="layui-inline layui-table-pageview" id="layui-table-page{{=d.index}}"></div>', "</div>", "<style>", "{{# layui.each(d.data.cols, function(i1, item1){", "layui.each(item1, function(i2, item2){ }}", ".laytable-cell-{{=d.index}}-{{=i1}}-{{=i2}}{ ", "{{# if(item2.width){ }}", "width: {{=item2.width}}px;", "{{# } }}", " }", "{{# });", "}); }}", "{{# if(d.data.lineStyle){", 'var cellClassName = ".layui-table-view-"+ d.index +" .layui-table-body .layui-table .layui-table-cell";', "}}", "{{= cellClassName }}{", "display: -webkit-box; -webkit-box-align: center; white-space: normal; {{- d.data.lineStyle }} ", "}", "{{= cellClassName }}:hover{overflow: auto;}", "{{# } }}", "{{# if(d.data.css){ }}", "{{- d.data.css }}", "{{# } }}", "</style>"].join(""),
        R = v(window),
        S = v(document),
        n = function(e) {
            this.index = ++k.index, this.config = v.extend({}, this.config, k.config, e), this.render()
        },
        y = (n.prototype.config = {
            limit: 10,
            loading: !0,
            escape: !0,
            cellMinWidth: 60,
            cellMaxWidth: Number.MAX_VALUE,
            editTrigger: "click",
            defaultToolbar: ["filter", "exports", "print"],
            autoSort: !0,
            text: {
                none: "\u65e0\u6570\u636e"
            }
        }, n.prototype.render = function(e) {
            var t = this,
                a = t.config;
            if (a.elem = v(a.elem), a.where = a.where || {}, a.id = "id" in a ? a.id : a.elem.attr("id") || t.index, a.request = v.extend({
                pageName: "page",
                limitName: "limit"
            }, a.request), a.response = v.extend({
                statusName: "code",
                statusCode: 0,
                msgName: "msg",
                dataName: "data",
                totalRowName: "totalRow",
                countName: "count"
            }, a.response), "object" == typeof a.page && (a.limit = a.page.limit || a.limit, a.limits = a.page.limits || a.limits, t.page = a.page.curr = a.page.curr || 1, delete a.page.elem, delete a.page.jump), !a.elem[0]) return t;
            if (a.elem.attr("lay-filter") || a.elem.attr("lay-filter", a.id), "reloadData" === e) return t.pullData(t.page, {
                type: "reloadData"
            });
            a.height && /^full-\d+$/.test(a.height) ? (t.fullHeightGap = a.height.split("-")[1], a.height = R.height() - t.fullHeightGap) : a.height && /^#\w+-{1}\d+$/.test(a.height) && (e = a.height.split("-"), t.parentHeightGap = e.pop(), t.parentDiv = e.join("-"), a.height = v(t.parentDiv).height() - t.parentHeightGap), a.index = t.index, t.key = a.id || a.index, t.setInit();
            var i, l, e = a.elem,
                n = e.next("." + L),
                o = t.elem = v("<div></div>");
            o.addClass((i = [L, L + "-" + t.index, "layui-form", "layui-border-box"], a.className && i.push(a.className), i.join(" "))).attr({
                "lay-filter": "LAY-TABLE-FORM-DF-" + t.index,
                "lay-id": a.id,
                style: (i = [], a.width && i.push("width:" + a.width + "px;"), a.height && i.push("height:" + a.height + "px;"), i.join(""))
            }).html(g(u).render({
                data: a,
                index: t.index
            })), n[0] && n.remove(), e.after(o), t.layTool = o.find(".layui-table-tool"), t.layBox = o.find(".layui-table-box"), t.layHeader = o.find(s), t.layMain = o.find(".layui-table-main"), t.layBody = o.find(N), t.layFixed = o.find(".layui-table-fixed"), t.layFixLeft = o.find(".layui-table-fixed-l"), t.layFixRight = o.find(".layui-table-fixed-r"), t.layTotal = o.find(".layui-table-total"), t.layPage = o.find(".layui-table-page"), t.renderToolbar(), t.renderPagebar(), t.fullSize(), 1 < a.cols.length && (i = t.layFixed.find(s).find("th"), l = t.layHeader.first(), layui.each(i, function(e, t) {
                (t = v(t)).height(l.find('th[data-key="' + t.attr("data-key") + '"]').height() + "px")
            })), t.pullData(t.page), t.events()
        }, n.prototype.initOpts = function(e) {
            this.config;
            e.checkbox && (e.type = "checkbox"), e.space && (e.type = "space"), e.type || (e.type = "normal"), "normal" !== e.type && (e.unresize = !0, e.width = e.width || {
                checkbox: 50,
                radio: 50,
                space: 30,
                numbers: 60
            }[e.type])
        }, n.prototype.setInit = function(e) {
            var l, a, d = this,
                r = d.config;
            if (r.clientWidth = r.width || (l = function(e) {
                var t, a = (e = e || r.elem.parent()).width();
                try {
                    t = "none" === e.css("display")
                } catch (i) {}
                return !e[0] || a && !t ? a : l(e.parent())
            })(), "width" === e) return r.clientWidth;
            r.css && -1 === r.css.indexOf(L) && (a = r.css.split("}"), layui.each(a, function(e, t) {
                t && (a[e] = "." + L + "-" + d.index + " " + t)
            }), r.css = a.join("}"));
            var c = function(a, e, i, l) {
                    var n, o;
                    l ? (l.key = [r.index, a, i].join("-"), l.hide = l.hide || !1, l.colspan = l.colspan || 0, l.rowspan = l.rowspan || 0, d.initOpts(l), (n = a + (parseInt(l.rowspan) || 1)) < r.cols.length ? (l.colGroup = !0, o = 0, layui.each(r.cols[n], function(e, t) {
                        t.HAS_PARENT || 1 <= o && o == (l.colspan || 1) || (t.HAS_PARENT = !0, t.parentKey = [r.index, a, i].join("-"), o += parseInt(1 < t.colspan ? t.colspan : 1), c(n, r.cols[n], e, t))
                    })) : l.colGroup = !1) : e.splice(i, 1)
                };
            layui.each(r.cols, function(a, i) {
                if (a) return !0;
                layui.each(i, function(e, t) {
                    c(a, i, e, t)
                })
            })
        }, n.prototype.renderToolbar = function() {
            var e = this.config,
                t = ['<div class="layui-inline" lay-event="add"><i class="layui-icon layui-icon-add-1"></i></div>', '<div class="layui-inline" lay-event="update"><i class="layui-icon layui-icon-edit"></i></div>', '<div class="layui-inline" lay-event="delete"><i class="layui-icon layui-icon-delete"></i></div>'].join(""),
                a = this.layTool.find(".layui-table-tool-temp"),
                i = ("default" === e.toolbar ? a.html(t) : "string" == typeof e.toolbar && (t = v(e.toolbar).html() || "") && a.html(g(t).render(e)), {
                    filter: {
                        title: "\u7b5b\u9009\u5217",
                        layEvent: "LAYTABLE_COLS",
                        icon: "layui-icon-cols"
                    },
                    exports: {
                        title: "\u5bfc\u51fa",
                        layEvent: "LAYTABLE_EXPORT",
                        icon: "layui-icon-export"
                    },
                    print: {
                        title: "\u6253\u5370",
                        layEvent: "LAYTABLE_PRINT",
                        icon: "layui-icon-print"
                    }
                }),
                l = [];
            "object" == typeof e.defaultToolbar && layui.each(e.defaultToolbar, function(e, t) {
                t = "string" == typeof t ? i[t] : t;
                t && l.push('<div class="layui-inline" title="' + t.title + '" lay-event="' + t.layEvent + '"><i class="layui-icon ' + t.icon + '"></i></div>')
            }), this.layTool.find(".layui-table-tool-self").html(l.join(""))
        }, n.prototype.renderPagebar = function() {
            var e, t = this.config,
                a = this.layPagebar = v('<div class="layui-inline layui-table-pagebar"></div>');
            t.pagebar && ((e = v(t.pagebar).html() || "") && a.append(g(e).render(t)), this.layPage.append(a))
        }, n.prototype.setParentCol = function(e, t) {
            var a = this.config,
                i = this.layHeader.find('th[data-key="' + t + '"]'),
                l = parseInt(i.attr("colspan")) || 0;
            i[0] && (t = t.split("-"), t = a.cols[t[1]][t[2]], e ? l-- : l++, i.attr("colspan", l), i[l < 1 ? "addClass" : "removeClass"](T), t.colspan = l, t.hide = l < 1, (a = i.data("parentkey")) && this.setParentCol(e, a))
        }, n.prototype.setColsPatch = function() {
            var a = this,
                e = a.config;
            layui.each(e.cols, function(e, t) {
                layui.each(t, function(e, t) {
                    t.hide && a.setParentCol(t.hide, t.parentKey)
                })
            })
        }, n.prototype.setGroupWidth = function(i) {
            var e, l = this;
            l.config.cols.length <= 1 || (e = l.layHeader.find((i ? "th[data-key=" + i.data("parentkey") + "]>" : "") + "." + _).get().reverse(), layui.each(e, function() {
                var e = v(this),
                    t = e.parent().data("key"),
                    a = 0;
                l.layHeader.eq(0).find("th[data-parentkey=" + t + "]").width(function(e, t) {
                    v(this).hasClass(T) || 0 < t && (a += t)
                }), a && e.css("max-width", a), i && e.parent().data("parentkey") && l.setGroupWidth(e.parent())
            }))
        }, n.prototype.setColsWidth = function() {
            var t, a, n = this,
                d = n.config,
                i = 0,
                r = 0,
                c = 0,
                s = 0,
                u = n.setInit("width"),
                e = (n.eachCols(function(e, t) {
                    t.hide || i++
                }), u = u - ("line" === d.skin || "nob" === d.skin ? 2 : i + 1) - n.getScrollWidth(n.layMain[0]) - 1, function(o) {
                    layui.each(d.cols, function(e, n) {
                        layui.each(n, function(e, t) {
                            var a = 0,
                                i = t.minWidth || d.cellMinWidth,
                                l = t.maxWidth || d.cellMaxWidth;
                            t ? t.colGroup || t.hide || (o ? c && c < i ? (r--, a = i) : c && l < c && (r--, a = l) : (a = t.width || 0, /\d+%$/.test(a) ? l < (a = (a = Math.floor(parseFloat(a) / 100 * u)) < i ? i : a) && (a = l) : a ? "normal" === t.type && (a < i && (t.width = a = i), l < a && (t.width = a = l)) : (t.width = a = 0, r++)), t.hide && (a = 0), s += a) : n.splice(e, 1)
                        })
                    }), s < u && 0 < r && (c = (u - s) / r)
                }),
                l = (e(), e(!0), n.autoColNums = r = 0 < r ? r : 0, n.eachCols(function(e, a) {
                    var i = a.minWidth || d.cellMinWidth,
                        l = a.maxWidth || d.cellMaxWidth;
                    a.colGroup || a.hide || (0 === a.width ? n.getCssRule(a.key, function(e) {
                        e.style.width = Math.floor(c < i ? i : l < c ? l : c) + "px"
                    }) : /\d+%$/.test(a.width) ? n.getCssRule(a.key, function(e) {
                        var t = Math.floor(parseFloat(a.width) / 100 * u);
                        e.style.width = (t = l < (t = t < i ? i : t) ? l : t) + "px"
                    }) : n.getCssRule(a.key, function(e) {
                        e.style.width = a.width + "px"
                    }))
                }), n.layMain.width() - n.getScrollWidth(n.layMain[0]) - n.layMain.children("table").outerWidth());
            0 < n.autoColNums && -i <= l && l <= i && (e = (a = (t = function(e) {
                return !(e = e || n.layHeader.eq(0).find("thead th:last-child")).data("field") && e.prev()[0] ? t(e.prev()) : e
            })()).data("key"), n.getCssRule(e, function(e) {
                var t = e.style.width || a.outerWidth();
                e.style.width = parseFloat(t) + l + "px", 0 < n.layMain.height() - n.layMain.prop("clientHeight") && (e.style.width = parseFloat(e.style.width) - 1 + "px")
            })), n.setGroupWidth(), n.layMain.find("tbody").is(":empty") && (e = n.layHeader.first().children("table").width(), n.layMain.find("table").width(e)), n.loading(!0)
        }, n.prototype.resize = function() {
            this.fullSize(), this.setColsWidth(), this.scrollPatch()
        }, n.prototype.reload = function(e, t, a) {
            var i = this;
            e = e || {}, delete i.haveInit, layui.each(e, function(e, t) {
                "array" === layui.type(t) && delete i.config[e]
            }), i.config = v.extend(t, {}, i.config, e), i.render(a)
        }, n.prototype.errorView = function(e) {
            var t = this,
                a = t.layMain.find("." + c),
                e = v('<div class="' + c + '">' + (e || "Error") + "</div>");
            a[0] && (t.layNone.remove(), a.remove()), t.layFixed.addClass(T), t.layMain.find("tbody").html(""), t.layMain.append(t.layNone = e), t.layTotal.addClass(r), t.layPage.find(D).addClass(r), k.cache[t.key] = [], t.syncCheckAll()
        }, n.prototype.page = 1, n.prototype.pullData = function(t, a) {
            var e, i = this,
                l = i.config,
                n = l.request,
                o = l.response,
                d = function() {
                    "object" == typeof l.initSort && i.sort(l.initSort.field, l.initSort.type)
                };
            a = a || {}, "function" == typeof l.before && l.before(l), i.startTime = (new Date).getTime(), l.url ? ((e = {})[n.pageName] = t, e[n.limitName] = l.limit, n = v.extend(e, l.where), l.contentType && 0 == l.contentType.indexOf("application/json") && (n = JSON.stringify(n)), i.loading(), v.ajax({
                type: l.method || "get",
                url: l.url,
                contentType: l.contentType,
                data: n,
                dataType: l.dataType || "json",
                jsonpCallback: l.jsonpCallback,
                headers: l.headers || {},
                success: function(e) {
                    (e = "function" == typeof l.parseData ? l.parseData(e) || e : e)[o.statusName] != o.statusCode ? (i.renderForm(), i.errorView(e[o.msgName] || '\u8fd4\u56de\u7684\u6570\u636e\u4e0d\u7b26\u5408\u89c4\u8303\uff0c\u6b63\u786e\u7684\u6210\u529f\u72b6\u6001\u7801\u5e94\u4e3a\uff1a"' + o.statusName + '": ' + o.statusCode)) : (i.renderData({
                        res: e,
                        curr: t,
                        count: e[o.countName],
                        type: a.type
                    }), d(), l.time = (new Date).getTime() - i.startTime + " ms"), i.setColsWidth(), "function" == typeof l.done && l.done(e, t, e[o.countName])
                },
                error: function(e, t) {
                    i.errorView("\u8bf7\u6c42\u5f02\u5e38\uff0c\u9519\u8bef\u63d0\u793a\uff1a" + t), i.renderForm(), i.setColsWidth(), "function" == typeof l.error && l.error(e, t)
                }
            })) : "array" === layui.type(l.data) && (e = t * l.limit - l.limit, (n = {})[o.dataName] = l.data.concat().splice(e, l.limit), n[o.countName] = l.data.length, "object" == typeof l.totalRow && (n[o.totalRowName] = v.extend({}, l.totalRow)), i.renderData({
                res: n,
                curr: t,
                count: n[o.countName],
                type: a.type
            }), d(), i.setColsWidth(), "function" == typeof l.done && l.done(n, t, n[o.countName]))
        }, n.prototype.eachCols = function(e) {
            return k.eachCols(null, e, this.config.cols), this
        }, n.prototype.col = function(e) {
            try {
                return e = e.split("-"), this.config.cols[e[1]][e[2]] || {}
            } catch (t) {
                return p.error(t), {}
            }
        }, n.prototype.renderData = function(e) {
            var u = this,
                y = u.config,
                t = e.res,
                l = e.curr,
                a = e.count,
                n = e.sort,
                h = t[y.response.dataName] || [],
                t = t[y.response.totalRowName],
                p = [],
                f = [],
                m = [],
                i = function() {
                    var s;
                    if (y.HAS_SET_COLS_PATCH || u.setColsPatch(), y.HAS_SET_COLS_PATCH = !0, !n && u.sortKey) return u.sort(u.sortKey.field, u.sortKey.sort, !0);
                    layui.each(h, function(o, d) {
                        var a = [],
                            i = [],
                            r = [],
                            c = o + y.limit * (l - 1) + 1;
                        if ("object" != typeof d) {
                            h[o] = d = {
                                LAY_KEY: d
                            };
                            try {
                                k.cache[u.key][o] = d
                            } catch (e) {}
                        }
                        "array" === layui.type(d) && 0 === d.length || (d[k.config.numbersName] = c, n || (d[k.config.indexName] = o), u.eachCols(function(e, l) {
                            var e = l.field || e,
                                t = l.key,
                                n = d[e];
                            n !== undefined && null !== n || (n = ""), l.colGroup || (t = ['<td data-field="' + e + '" data-key="' + t + '" ' + (e = [], l.edit && e.push('data-edit="true"'), l.templet && e.push('data-content="' + x.escape(n) + '"'), l.toolbar && e.push('data-off="true"'), l.event && e.push('lay-event="' + l.event + '"'), l.minWidth && e.push('data-minwidth="' + l.minWidth + '"'), l.maxWidth && e.push('data-maxwidth="' + l.maxWidth + '"'), e.join(" ")) + ' class="' + (e = [], l.hide && e.push(T), l.field || e.push(j), e.join(" ")) + '">', '<div class="layui-table-cell laytable-cell-' + ("normal" === l.type ? t : t + " laytable-cell-" + l.type) + '"' + (l.align ? ' align="' + l.align + '"' : "") + (e = [], l.style && e.push('style="' + l.style + '"'), e.join(" ")) + ">" +
                            function() {
                                var e, t = v.extend(!0, {
                                    LAY_COL: l
                                }, d),
                                    a = k.config.checkName,
                                    i = k.config.disabledName;
                                switch (l.type) {
                                case "checkbox":
                                    return '<input type="checkbox" name="layTableCheckbox" lay-skin="primary" ' + (e = [], l[a] && (d[a] = l[a], l[a] && (e[0] = "checked")), t[a] && (e[0] = "checked"), t[i] && e.push("disabled"), e.join(" ")) + ">";
                                case "radio":
                                    return t[a] && (s = o), '<input type="radio" name="layTableRadio_' + y.index + '" ' + (e = [], t[a] && (e[0] = "checked"), t[i] && e.push("disabled"), e.join(" ")) + ' lay-type="layTableRadio">';
                                case "numbers":
                                    return c
                                }
                                return l.toolbar ? g(v(l.toolbar).html() || "").render(t) : C.call(u, {
                                    item3: l,
                                    content: n,
                                    tplData: t
                                })
                            }(), "</div></td>"].join(""), a.push(t), l.fixed && "right" !== l.fixed && i.push(t), "right" === l.fixed && r.push(t))
                        }), p.push('<tr data-index="' + o + '">' + a.join("") + "</tr>"), f.push('<tr data-index="' + o + '">' + i.join("") + "</tr>"), m.push('<tr data-index="' + o + '">' + r.join("") + "</tr>"))
                    }), "fixed" === y.scrollPos && "reloadData" === e.type || u.layBody.scrollTop(0), "reset" === y.scrollPos && u.layBody.scrollLeft(0), u.layMain.find("." + c).remove(), u.layMain.find("tbody").html(p.join("")), u.layFixLeft.find("tbody").html(f.join("")), u.layFixRight.find("tbody").html(m.join("")), u.renderForm(), "number" == typeof s && u.setThisRowChecked(s), u.syncCheckAll(), u.fullSize(), u.haveInit ? u.scrollPatch() : setTimeout(function() {
                        u.scrollPatch()
                    }, 50), u.haveInit = !0, b.close(u.tipsIndex)
                };
            return k.cache[u.key] = h, u.layTotal[0 == h.length ? "addClass" : "removeClass"](r), u.layPage[y.page || y.pagebar ? "removeClass" : "addClass"](T), u.layPage.find(D)[!y.page || 0 == a || 0 === h.length && 1 == l ? "addClass" : "removeClass"](r), 0 === h.length ? (u.renderForm(), u.errorView(y.text.none)) : (u.layFixLeft.removeClass(T), n ? i() : (i(), u.renderTotal(h, t), u.layTotal && u.layTotal.removeClass(T), void(y.page && (y.page = v.extend({
                elem: "layui-table-page" + y.index,
                count: a,
                limit: y.limit,
                limits: y.limits || [10, 20, 30, 40, 50, 60, 70, 80, 90],
                groups: 3,
                layout: ["prev", "page", "next", "skip", "count", "limit"],
                prev: '<i class="layui-icon">&#xe603;</i>',
                next: '<i class="layui-icon">&#xe602;</i>',
                jump: function(e, t) {
                    t || (u.page = e.curr, y.limit = e.limit, u.pullData(e.curr))
                }
            }, y.page), y.page.count = a, o.render(y.page)))))
        }, n.prototype.renderTotal = function(e, o) {
            var d, r = this,
                c = r.config,
                s = {};
            c.totalRow && (layui.each(e, function(e, i) {
                "array" === layui.type(i) && 0 === i.length || r.eachCols(function(e, t) {
                    var e = t.field || e,
                        a = i[e];
                    t.totalRow && (s[e] = (s[e] || 0) + (parseFloat(a) || 0))
                })
            }), r.dataTotal = {}, d = [], r.eachCols(function(e, t) {
                var a, e = t.field || e,
                    i = o && o[t.field],
                    l = (a = t.totalRowText || "", n = "totalRowDecimals" in t ? t.totalRowDecimals : 2, n = parseFloat(s[e]).toFixed(n), (l = {
                        LAY_COL: t
                    })[e] = n, n = t.totalRow && C.call(r, {
                        item3: t,
                        content: n,
                        tplData: l
                    }) || a, i || n),
                    n = ['<td data-field="' + e + '" data-key="' + t.key + '" ' + (a = [], t.align && a.push('align="' + t.align + '"'), t.minWidth && a.push('data-minwidth="' + t.minWidth + '"'), t.maxWidth && a.push('data-maxwidth="' + t.maxWidth + '"'), a.join(" ")) + ' class="' + (n = [], t.hide && n.push(T), t.field || n.push(j), n.join(" ")) + '">', '<div class="layui-table-cell laytable-cell-' + (a = t.key, "normal" === t.type ? a : a + " laytable-cell-" + t.type) + '"' + (n = [], t.style && n.push('style="' + t.style + '"'), n.join(" ")) + ">" + ("string" == typeof(a = t.totalRow || c.totalRow) ? g(a).render(v.extend({
                        TOTAL_NUMS: i || s[e],
                        LAY_COL: t
                    }, t)) : l), "</div></td>"].join("");
                t.field && (r.dataTotal[e] = l), d.push(n)
            }), r.layTotal.find("tbody").html("<tr>" + d.join("") + "</tr>"))
        }, n.prototype.getColElem = function(e, t) {
            this.config;
            return e.eq(0).find(".laytable-cell-" + t + ":eq(0)")
        }, n.prototype.renderForm = function(e) {
            this.config;
            var t = this.elem.attr("lay-filter");
            h.render(e, t)
        }, n.prototype.setThisRowChecked = function(e) {
            this.config;
            var t = "layui-table-click";
            this.layBody.find('tr[data-index="' + e + '"]').addClass(t).siblings("tr").removeClass(t)
        }, n.prototype.sort = function(l, e, t, a) {
            var i, n = this,
                o = {},
                d = n.config,
                r = d.elem.attr("lay-filter"),
                c = k.cache[n.key];
            "string" == typeof l && (s = l, n.layHeader.find("th").each(function(e, t) {
                var a = v(this),
                    i = a.data("field");
                if (i === l) return l = a, s = i, !1
            }));
            try {
                var s = s || l.data("field"),
                    u = l.data("key");
                if (n.sortKey && !t && s === n.sortKey.field && e === n.sortKey.sort) return;
                var y = n.layHeader.find("th .laytable-cell-" + u).find(W);
                n.layHeader.find("th").find(W).removeAttr("lay-sort"), y.attr("lay-sort", e || null), n.layFixed.find("th")
            } catch (h) {
                p.error("Table modules: sort field '" + s + "' not matched")
            }
            n.sortKey = {
                field: s,
                sort: e
            }, d.autoSort && ("asc" === e ? i = layui.sort(c, s) : "desc" === e ? i = layui.sort(c, s, !0) : (i = layui.sort(c, k.config.indexName), delete n.sortKey, delete d.initSort)), o[d.response.dataName] = i || c, n.renderData({
                res: o,
                curr: n.page,
                count: n.count,
                sort: !0
            }), a && (d.initSort = {
                field: s,
                type: e
            }, layui.event.call(l, w, "sort(" + r + ")", v.extend({
                config: d
            }, d.initSort)))
        }, n.prototype.loading = function(e) {
            var t = this;
            t.config.loading && (e ? (t.layInit && t.layInit.remove(), delete t.layInit, t.layBox.find(".layui-table-init").remove()) : (t.layInit = v(['<div class="layui-table-init">', '<i class="layui-icon layui-icon-loading layui-anim layui-anim-rotate layui-anim-loop"></i>', "</div>"].join("")), t.layBox.append(t.layInit)))
        }, n.prototype.setCheckData = function(e, t) {
            var a = this.config,
                i = k.cache[this.key];
            i[e] && "array" !== layui.type(i[e]) && (i[e][a.checkName] = t)
        }, n.prototype.syncCheckAll = function() {
            var e = this,
                i = e.config,
                t = e.layHeader.find('input[name="layTableCheckbox"]'),
                a = function(a) {
                    return e.eachCols(function(e, t) {
                        "checkbox" === t.type && (t[i.checkName] = a)
                    }), a
                };
            t[0] && (k.checkStatus(e.key).isAll ? (t[0].checked || (t.prop("checked", !0), e.renderForm("checkbox")), a(!0)) : (t[0].checked && (t.prop("checked", !1), e.renderForm("checkbox")), a(!1)))
        }, n.prototype.getCssRule = function(a, i) {
            var e = this.elem.find("style")[0],
                e = e.sheet || e.styleSheet || {},
                e = e.cssRules || e.rules;
            layui.each(e, function(e, t) {
                if (t.selectorText === ".laytable-cell-" + a) return i(t), !0
            })
        }, n.prototype.fullSize = function() {
            var e = this,
                t = e.config,
                a = t.height;
            e.fullHeightGap ? (a = R.height() - e.fullHeightGap, e.elem.css("height", a = a < 135 ? 135 : a)) : e.parentDiv && e.parentHeightGap && (a = v(e.parentDiv).height() - e.parentHeightGap, e.elem.css("height", a = a < 135 ? 135 : a)), a && (a = parseFloat(a) - (e.layHeader.outerHeight() || 38), t.toolbar && (a -= e.layTool.outerHeight() || 50), t.totalRow && (a -= e.layTotal.outerHeight() || 40), (t.page || t.pagebar) && (a -= e.layPage.outerHeight() || 43), e.layMain.outerHeight(a))
        }, n.prototype.getScrollWidth = function(e) {
            var t = 0;
            return e ? t = e.offsetWidth - e.clientWidth : ((e = document.createElement("div")).style.width = "100px", e.style.height = "100px", e.style.overflowY = "scroll", document.body.appendChild(e), t = e.offsetWidth - e.clientWidth, document.body.removeChild(e)), t
        }, n.prototype.scrollPatch = function() {
            var e = this,
                t = e.layMain.children("table"),
                a = e.layMain.width() - e.layMain.prop("clientWidth"),
                i = e.layMain.height() - e.layMain.prop("clientHeight"),
                l = (e.getScrollWidth(e.layMain[0]), t.outerWidth() - e.layMain.width()),
                n = function(e) {
                    var t;
                    a && i ? (e = e.eq(0)).find(".layui-table-patch")[0] || ((t = v('<th class="layui-table-patch"><div class="layui-table-cell"></div></th>')).find("div").css({
                        width: a
                    }), e.find("tr").append(t)) : e.find(".layui-table-patch").remove()
                };
            n(e.layHeader), n(e.layTotal);
            n = e.layMain.height() - i;
            e.layFixed.find(N).css("height", t.height() >= n ? n : "auto"), e.layFixRight[0 < l ? "removeClass" : "addClass"](T), e.layFixRight.css("right", a - 1)
        }, n.prototype.events = function() {
            var s = this,
                u = s.config,
                r = u.elem.attr("lay-filter"),
                e = s.layHeader.find("th"),
                y = ".layui-table-cell",
                n = v("body"),
                o = {},
                d = (s.layTool.on("click", "*[lay-event]", function(e) {
                    var a, i = v(this),
                        t = i.attr("lay-event"),
                        l = function(e) {
                            var t = v(e.list),
                                a = v('<ul class="layui-table-tool-panel"></ul>');
                            a.html(t), u.height && a.css("max-height", u.height - (s.layTool.outerHeight() || 50)), i.find(".layui-table-tool-panel")[0] || i.append(a), s.renderForm(), a.on("click", function(e) {
                                layui.stope(e)
                            }), e.done && e.done(a, t)
                        };
                    switch (layui.stope(e), S.trigger("table.tool.panel.remove"), b.close(s.tipsIndex), t) {
                    case "LAYTABLE_COLS":
                        l({
                            list: (a = [], s.eachCols(function(e, t) {
                                t.field && "normal" == t.type && a.push('<li><input type="checkbox" name="' + t.field + '" data-key="' + t.key + '" data-parentkey="' + (t.parentKey || "") + '" lay-skin="primary" ' + (t.hide ? "" : "checked") + ' title="' + x.escape(v("<div>" + (t.title || t.field) + "</div>").text()) + '" lay-filter="LAY_TABLE_TOOL_COLS"></li>')
                            }), a.join("")),
                            done: function() {
                                h.on("checkbox(LAY_TABLE_TOOL_COLS)", function(e) {
                                    var e = v(e.elem),
                                        t = this.checked,
                                        a = e.data("key"),
                                        i = s.col(a),
                                        l = i.hide,
                                        e = e.data("parentkey");
                                    i.key && (i.hide = !t, s.elem.find('*[data-key="' + a + '"]')[t ? "removeClass" : "addClass"](T), l != i.hide && s.setParentCol(!t, e), s.resize(), layui.event.call(this, w, "colToggled(" + r + ")", {
                                        col: i,
                                        config: u
                                    }))
                                })
                            }
                        });
                        break;
                    case "LAYTABLE_EXPORT":
                        f.ie ? b.tips("\u5bfc\u51fa\u529f\u80fd\u4e0d\u652f\u6301 IE\uff0c\u8bf7\u7528 Chrome \u7b49\u9ad8\u7ea7\u6d4f\u89c8\u5668\u5bfc\u51fa", this, {
                            tips: 3
                        }) : l({
                            list: ['<li data-type="csv">\u5bfc\u51fa csv \u683c\u5f0f\u6587\u4ef6</li>', '<li data-type="xls">\u5bfc\u51fa xls \u683c\u5f0f\u6587\u4ef6</li>'].join(""),
                            done: function(e, t) {
                                t.on("click", function() {
                                    var e = v(this).data("type");
                                    k.exportFile.call(s, u.id, null, e)
                                })
                            }
                        });
                        break;
                    case "LAYTABLE_PRINT":
                        var n = window.open("about:blank", "_blank"),
                            o = ["<style>", "body{font-size: 12px; color: #5F5F5F;}", "table{width: 100%; border-collapse: collapse; border-spacing: 0;}", "th,td{line-height: 20px; padding: 9px 15px; border: 1px solid #ccc; text-align: left; font-size: 12px; color: #5F5F5F;}", "a{color: #5F5F5F; text-decoration:none;}", "*.layui-hide{display: none}", "</style>"].join(""),
                            d = v(s.layHeader.html());
                        d.append(s.layMain.find("table").html()), d.append(s.layTotal.find("table").html()), d.find("th.layui-table-patch").remove(), d.find("thead>tr>th." + j).filter(function(e, t) {
                            return !v(t).children("." + _).length
                        }).remove(), d.find("tbody>tr>td." + j).remove(), n.document.write(o + d.prop("outerHTML")), n.document.close(), n.print(), n.close()
                    }
                    layui.event.call(this, w, "toolbar(" + r + ")", v.extend({
                        event: t,
                        config: u
                    }, {}))
                }), s.layPagebar.on("click", "*[lay-event]", function(e) {
                    var t = v(this).attr("lay-event");
                    layui.event.call(this, w, "pagebar(" + r + ")", v.extend({
                        event: t,
                        config: u
                    }, {}))
                }), e.on("mousemove", function(e) {
                    var t = v(this),
                        a = t.offset().left,
                        e = e.clientX - a;
                    t.data("unresize") || m.eventMoveElem || (o.allowResize = t.width() - e <= 10, n.css("cursor", o.allowResize ? "col-resize" : ""))
                }).on("mouseleave", function() {
                    v(this);
                    m.eventMoveElem || n.css("cursor", "")
                }).on("mousedown", function(e) {
                    var t, a = v(this);
                    o.allowResize && (t = a.data("key"), e.preventDefault(), o.offset = [e.clientX, e.clientY], s.getCssRule(t, function(e) {
                        var t = e.style.width || a.outerWidth();
                        o.rule = e, o.ruleWidth = parseFloat(t), o.minWidth = a.data("minwidth") || u.cellMinWidth, o.maxWidth = a.data("maxwidth") || u.cellMaxWidth
                    }), a.data(M, o), m.eventMoveElem = a)
                }), m.docEvent || S.on("mousemove", function(e) {
                    var t, a;
                    m.eventMoveElem && (t = m.eventMoveElem.data(M) || {}, m.eventMoveElem.data("resizing", 1), e.preventDefault(), t.rule && (e = t.ruleWidth + e.clientX - t.offset[0], a = m.eventMoveElem.closest("." + L).attr("lay-id"), (a = m.that[a]) && ((e = e < t.minWidth ? t.minWidth : e) > t.maxWidth && (e = t.maxWidth), t.rule.style.width = e + "px", a.setGroupWidth(m.eventMoveElem), b.close(s.tipsIndex))))
                }).on("mouseup", function(e) {
                    var t, a, i, l;
                    m.eventMoveElem && (i = (t = m.eventMoveElem).closest("." + L).attr("lay-id"), (a = m.that[i]) && (i = t.data("key"), l = a.col(i), o = {}, n.css("cursor", ""), a.scrollPatch(), t.removeData(M), delete m.eventMoveElem, a.getCssRule(i, function(e) {
                        l.width = parseFloat(e.style.width), layui.event.call(t[0], w, "colResized(" + r + ")", {
                            col: l,
                            config: a.config
                        })
                    })))
                }), m.docEvent = !0, e.on("click", function(e) {
                    var t = v(this),
                        a = t.find(W),
                        i = a.attr("lay-sort");
                    if (!a[0] || 1 === t.data("resizing")) return t.removeData("resizing");
                    s.sort(t, "asc" === i ? "desc" : "desc" === i ? null : "asc", null, !0)
                }).find(W + " .layui-edge ").on("click", function(e) {
                    var t = v(this),
                        a = t.index(),
                        t = t.parents("th").eq(0).data("field");
                    layui.stope(e), 0 === a ? s.sort(t, "asc", null, !0) : s.sort(t, "desc", null, !0)
                }), s.commonMember = function(e) {
                    var t = v(this).parents("tr").eq(0).data("index"),
                        r = s.layBody.find('tr[data-index="' + t + '"]'),
                        c = (c = k.cache[s.key] || [])[t] || {};
                    return v.extend({
                        tr: r,
                        config: u,
                        data: k.clearCacheKey(c),
                        del: function() {
                            k.cache[s.key][t] = [], r.remove(), s.scrollPatch()
                        },
                        update: function(e, d) {
                            e = e || {}, layui.each(e, function(i, l) {
                                var n = r.children('td[data-field="' + i + '"]'),
                                    o = n.children(y);
                                i in c && (c[i] = l), s.eachCols(function(e, t) {
                                    var a;
                                    t.field == i ? (o.html(C.call(s, {
                                        item3: t,
                                        content: l,
                                        tplData: v.extend({
                                            LAY_COL: t
                                        }, c)
                                    })), n.data("content", l)) : d && (t.templet || t.toolbar) && (e = r.children('td[data-field="' + (t.field || e) + '"]'), a = c[t.field], e.children(y).html(C.call(s, {
                                        item3: t,
                                        content: a,
                                        tplData: v.extend({
                                            LAY_COL: t
                                        }, c)
                                    })), e.data("content", a))
                                })
                            }), s.renderForm()
                        }
                    }, e)
                }),
                t = (s.elem.on("click", 'input[name="layTableCheckbox"]+', function() {
                    var e = v(this).prev(),
                        t = s.layBody.find('input[name="layTableCheckbox"]'),
                        a = e.parents("tr").eq(0).data("index"),
                        i = e[0].checked,
                        l = "layTableAllChoose" === e.attr("lay-filter");
                    e[0].disabled || (l ? (t.each(function(e, t) {
                        t.checked = i, s.setCheckData(e, i)
                    }), s.syncCheckAll(), s.renderForm("checkbox")) : (s.setCheckData(a, i), s.syncCheckAll()), layui.event.call(e[0], w, "checkbox(" + r + ")", d.call(e[0], {
                        checked: i,
                        type: l ? "all" : "one"
                    })))
                }), s.elem.on("click", 'input[lay-type="layTableRadio"]+', function() {
                    var e = v(this).prev(),
                        t = e[0].checked,
                        a = k.cache[s.key],
                        i = e.parents("tr").eq(0).data("index");
                    layui.each(a, function(e, t) {
                        i === e ? t[u.checkName] = !0 : delete t[u.checkName]
                    }), s.setThisRowChecked(i), layui.event.call(this, w, "radio(" + r + ")", d.call(this, {
                        checked: t
                    }))
                }), s.layBody.on("mouseenter", "tr", function() {
                    var e = v(this),
                        t = e.index();
                    e.data("off") || s.layBody.find("tr:eq(" + t + ")").addClass(E)
                }).on("mouseleave", "tr", function() {
                    var e = v(this),
                        t = e.index();
                    e.data("off") || s.layBody.find("tr:eq(" + t + ")").removeClass(E)
                }).on("click", "tr", function() {
                    t.call(this, "row")
                }).on("dblclick", "tr", function() {
                    t.call(this, "rowDouble")
                }), function(e) {
                    var t = v(this);
                    t.data("off") || layui.event.call(this, w, e + "(" + r + ")", d.call(t.children("td")[0]))
                }),
                c = function(e, t) {
                    var a, i, l, n;
                    (e = v(e)).data("off") || (a = e.data("field"), n = e.data("key"), n = s.col(n), i = e.closest("tr").data("index"), i = k.cache[s.key][i], l = e.children(y), (n = "function" == typeof n.edit ? n.edit(i) : n.edit) && ((n = v("textarea" === n ? '<textarea class="layui-input ' + A + '"></textarea>' : '<input class="layui-input ' + A + '">'))[0].value = e.data("content") || i[a] || l.text(), e.find("." + A)[0] || e.append(n), n.focus(), t && layui.stope(t)))
                },
                i = (s.layBody.on("change", "." + A, function() {
                    var e = v(this),
                        t = e.parent(),
                        a = this.value,
                        i = e.parent().data("field"),
                        e = e.closest("tr").data("index"),
                        e = k.cache[s.key][e],
                        l = d.call(t[0], {
                            value: a,
                            field: i,
                            oldValue: e[i],
                            td: t,
                            reedit: function() {
                                setTimeout(function() {
                                    c(l.td);
                                    var e = {};
                                    e[i] = l.oldValue, l.update(e)
                                })
                            }
                        }),
                        e = {};
                    e[i] = a, l.update(e), layui.event.call(t[0], w, "edit(" + r + ")", l)
                }).on("blur", "." + A, function() {
                    v(this).remove()
                }), s.layBody.on(u.editTrigger, "td", function(e) {
                    c(this, e)
                }).on("mouseenter", "td", function() {
                    a.call(this)
                }).on("mouseleave", "td", function() {
                    a.call(this, "hide")
                }), "layui-table-grid-down"),
                a = function(e) {
                    var t = v(this),
                        a = t.children(y);
                        // Math.ceil() 四舍五入a.outerWidth(
                    t.data("off") || (e ? t.find(".layui-table-grid-down").remove() : !(a.prop("scrollWidth") > Math.ceil(a.outerWidth()) || 0 < a.find("br").length) || u.lineStyle || a.find("." + i)[0] 
                    // update
                    // || t.append('<div class="' + i + '"><i class="layui-icon layui-icon-down"></i></div>')
                    || v(a).attr("title",v(a).text())
                    )
                },
                l = (s.layBody.on("click", "." + i, function(e) {
                    var t = v(this).parent().children(y);
                    s.tipsIndex = b.tips(['<div class="layui-table-tips-main" style="margin-top: -' + (t.height() + 23) + "px;" + ("sm" === u.size ? "padding: 4px 15px; font-size: 12px;" : "lg" === u.size ? "padding: 14px 15px;" : "") + '">', t.html(), "</div>", '<i class="layui-icon layui-table-tips-c layui-icon-close"></i>'].join(""), t[0], {
                        tips: [3, ""],
                        time: -1,
                        anim: -1,
                        maxWidth: f.ios || f.android ? 300 : s.elem.width() / 2,
                        isOutAnim: !1,
                        skin: "layui-table-tips",
                        success: function(e, t) {
                            e.find(".layui-table-tips-c").on("click", function() {
                                b.close(t)
                            })
                        }
                    }), layui.stope(e)
                }), function(e) {
                    var t = v(this),
                        a = t.parents("tr").eq(0).data("index");
                    layui.event.call(this, w, (e || "tool") + "(" + r + ")", d.call(this, {
                        event: t.attr("lay-event")
                    })), s.setThisRowChecked(a)
                });
            s.layBody.on("click", "*[lay-event]", function(e) {
                l.call(this), layui.stope(e)
            }).on("dblclick", "*[lay-event]", function(e) {
                l.call(this, "toolDouble"), layui.stope(e)
            }), s.layMain.on("scroll", function() {
                var e = v(this),
                    t = e.scrollLeft(),
                    e = e.scrollTop();
                s.layHeader.scrollLeft(t), s.layTotal.scrollLeft(t), s.layFixed.find(N).scrollTop(e), b.close(s.tipsIndex)
            }), R.on("resize", function() {
                s.resize()
            })
        }, S.on("click", function() {
            S.trigger("table.remove.tool.panel")
        }), S.on("table.remove.tool.panel", function() {
            v(".layui-table-tool-panel").remove()
        }), k.init = function(a, i) {
            i = i || {};
            var e = v(a ? 'table[lay-filter="' + a + '"]' : t + "[lay-data]," + t + "[lay-options]"),
                l = "Table element property lay-data configuration item has a syntax error: ";
            return e.each(function() {
                var e = v(this),
                    t = e.attr("lay-data"),
                    t = d.options(this, {
                        attr: t ? "lay-data" : null,
                        errorText: l + (t || e.attr("lay-options"))
                    }),
                    n = [],
                    o = v.extend({
                        elem: this,
                        cols: [],
                        data: [],
                        skin: e.attr("lay-skin"),
                        size: e.attr("lay-size"),
                        even: "string" == typeof e.attr("lay-even")
                    }, k.config, i, t);
                a && e.hide(), e.find("thead>tr").each(function(i) {
                    o.cols[i] = [], v(this).children().each(function(e) {
                        var t = v(this),
                            a = t.attr("lay-data"),
                            a = d.options(this, {
                                attr: a ? "lay-data" : null,
                                errorText: l + (a || t.attr("lay-options"))
                            }),
                            t = v.extend({
                                title: t.text(),
                                colspan: t.attr("colspan") || 0,
                                rowspan: t.attr("rowspan") || 0
                            }, a);
                        t.colspan < 2 && n.push(t), o.cols[i].push(t)
                    })
                }), e.find("tbody>tr").each(function(e) {
                    var a = v(this),
                        l = {};
                    a.children("td").each(function(e, t) {
                        var a = v(this),
                            i = a.data("field");
                        if (i) return l[i] = a.html()
                    }), layui.each(n, function(e, t) {
                        e = a.children("td").eq(e);
                        l[t.field] = e.html()
                    }), o.data[e] = l
                }), k.render(o)
            }), this
        }, m.that = {}, m.config = {}, function(a, i, e, l) {
            var n, o;
            l.colGroup && (n = 0, a++, l.CHILD_COLS = [], o = e + (parseInt(l.rowspan) || 1), layui.each(i[o], function(e, t) {
                t.parentKey ? t.parentKey === l.key && (t.PARENT_COL_INDEX = a, l.CHILD_COLS.push(t), y(a, i, o, t)) : t.PARENT_COL_INDEX || 1 <= n && n == (l.colspan || 1) || (t.PARENT_COL_INDEX = a, l.CHILD_COLS.push(t), n += t.hide ? 0 : parseInt(1 < t.colspan ? t.colspan : 1), y(a, i, o, t))
            }))
        });
    k.eachCols = function(e, a, i) {
        var e = m.config[e] || {},
            l = [],
            n = (i = v.extend(!0, [], i || e.cols), layui.each(i, function(a, e) {
                if (a) return !0;
                layui.each(e, function(e, t) {
                    y(0, i, a, t), t.PARENT_COL_INDEX || l.push(t)
                })
            }), function(e) {
                layui.each(e || l, function(e, t) {
                    if (t.CHILD_COLS) return n(t.CHILD_COLS);
                    "function" == typeof a && a(e, t)
                })
            });
        n()
    }, k.checkStatus = function(e) {
        var a = 0,
            i = 0,
            l = [],
            e = k.cache[e] || [];
        return layui.each(e, function(e, t) {
            "array" === layui.type(t) ? i++ : t[k.config.checkName] && (a++, t[k.config.disabledName] || l.push(k.clearCacheKey(t)))
        }), {
            data: l,
            isAll: !! e.length && a === e.length - i
        }
    }, k.getData = function(e) {
        var a = [],
            e = k.cache[e] || [];
        return layui.each(e, function(e, t) {
            "array" !== layui.type(t) && a.push(k.clearCacheKey(t))
        }), a
    }, k.exportFile = function(e, t, a) {
        t = t || k.clearCacheKey(k.cache[e]);
        var d, i, l, r, n = (a = "object" == typeof a ? a : (n = {}, a && (n.type = a), n)).type || "csv",
            c = m.that[e],
            o = m.config[e] || {},
            s = {
                csv: "text/csv",
                xls: "application/vnd.ms-excel"
            }[n],
            u = document.createElement("a");
        if (f.ie) return p.error("IE_NOT_SUPPORT_EXPORTS");
        u.href = "data:" + s + ";charset=utf-8,\ufeff" + encodeURIComponent((d = [], i = [], l = [], r = {}, layui.each(t, function(l, n) {
            var o = [];
            "object" == typeof e ? (layui.each(e, function(e, t) {
                0 == l && d.push(t || "")
            }), layui.each(k.clearCacheKey(n), function(e, t) {
                o.push('"' + (t || "") + '"')
            })) : k.eachCols(e, function(e, t) {
                var a, i;
                t.field && "normal" == t.type && (t.hide ? 0 == l && (r[t.field] = !0) : (a = n[t.field], i = c.layBody.find('tr[data-index="' + l + '"]>td'), a !== undefined && null !== a || (a = ""), 0 == l && d.push(t.title || ""), o.push('"' + C.call(c, {
                    item3: t,
                    content: a,
                    tplData: n,
                    text: "text",
                    obj: c.commonMember.call(i.eq(0), {
                        td: function(e) {
                            return i.filter('[data-field="' + e + '"]')
                        }
                    })
                }) + '"')))
            }), i.push(o.join(","))
        }), c && layui.each(c.dataTotal, function(e, t) {
            r[e] || l.push(t)
        }), d.join(",") + "\r\n" + i.join("\r\n") + "\r\n" + l.join(","))), u.download = (a.title || o.title || "table_" + (o.index || "")) + "." + n, document.body.appendChild(u), u.click(), document.body.removeChild(u)
    }, k.resize = function(e) {
        e ? l(e) && m.that[e].resize() : layui.each(m.that, function() {
            this.resize()
        })
    }, k.reload = function(e, t, a, i) {
        if (l(e)) return e = m.that[e], e.reload(t, a, i), m.call(e)
    }, k.reloadData = function() {
        var a = v.extend([], arguments),
            i = (a[3] = "reloadData", new RegExp("^(" + ["data", "url", "method", "contentType", "dataType", "jsonpCallback", "headers", "where", "page", "limit", "request", "response", "parseData", "scrollPos"].join("|") + ")$"));
        return layui.each(a[1], function(e, t) {
            i.test(e) || delete a[1][e]
        }), k.reload.apply(null, a)
    }, k.render = function(e) {
        e = new n(e);
        return m.call(e)
    }, k.clearCacheKey = function(e) {
        return delete(e = v.extend({}, e))[k.config.checkName], delete e[k.config.indexName], delete e[k.config.numbersName], delete e[k.config.disabledName], e
    }, v(function() {
        k.init()
    }), e(w, k)
});
layui.define("form", function(e) {
    "use strict";
    var u = layui.$,
        i = layui.form,
        p = layui.layer,
        n = "tree",
        a = {
            config: {},
            index: layui[n] ? layui[n].index + 1e4 : 0,
            set: function(e) {
                var i = this;
                return i.config = u.extend({}, i.config, e), i
            },
            on: function(e, i) {
                return layui.onevent.call(this, n, e, i)
            }
        },
        t = function() {
            var i = this,
                e = i.config,
                n = e.id || i.index;
            return t.that[n] = i, {
                config: t.config[n] = e,
                reload: function(e) {
                    i.reload.call(i, e)
                },
                getChecked: function() {
                    return i.getChecked.call(i)
                },
                setChecked: function(e) {
                    return i.setChecked.call(i, e)
                }
            }
        },
        y = "layui-hide",
        d = "layui-disabled",
        f = "layui-tree-set",
        C = "layui-tree-iconClick",
        k = "layui-icon-addition",
        v = "layui-icon-subtraction",
        m = "layui-tree-entry",
        x = "layui-tree-main",
        b = "layui-tree-txt",
        g = "layui-tree-pack",
        w = "layui-tree-spread",
        N = "layui-tree-setLineShort",
        T = "layui-tree-showLine",
        L = "layui-tree-lineExtend",
        l = function(e) {
            var i = this;
            i.index = ++a.index, i.config = u.extend({}, i.config, a.config, e), i.render()
        };
    l.prototype.config = {
        data: [],
        showCheckbox: !1,
        showLine: !0,
        accordion: !1,
        onlyIconControl: !1,
        isJump: !1,
        edit: !1,
        text: {
            defaultNodeName: "\u672a\u547d\u540d",
            none: "\u65e0\u6570\u636e"
        }
    }, l.prototype.reload = function(e) {
        var n = this;
        layui.each(e, function(e, i) {
            "array" === layui.type(i) && delete n.config[e]
        }), n.config = u.extend(!0, {}, n.config, e), n.render()
    }, l.prototype.render = function() {
        var e = this,
            i = e.config,
            n = (e.checkids = [], u('<div class="layui-tree' + (i.showCheckbox ? " layui-form" : "") + (i.showLine ? " layui-tree-line" : "") + '" lay-filter="LAY-tree-' + e.index + '"></div>')),
            a = (e.tree(n), i.elem = u(i.elem));
        if (a[0]) {
            if (e.key = i.id || e.index, e.elem = n, e.elemNone = u('<div class="layui-tree-emptyText">' + i.text.none + "</div>"), a.html(e.elem), 0 == e.elem.find(".layui-tree-set").length) return e.elem.append(e.elemNone);
            i.showCheckbox && e.renderForm("checkbox"), e.elem.find(".layui-tree-set").each(function() {
                var e = u(this);
                e.parent(".layui-tree-pack")[0] || e.addClass("layui-tree-setHide"), !e.next()[0] && e.parents(".layui-tree-pack").eq(1).hasClass("layui-tree-lineExtend") && e.addClass(N), e.next()[0] || e.parents(".layui-tree-set").eq(0).next()[0] || e.addClass(N)
            }), e.events()
        }
    }, l.prototype.renderForm = function(e) {
        i.render(e, "LAY-tree-" + this.index)
    }, l.prototype.tree = function(l, e) {
        var r = this,
            c = r.config,
            e = e || c.data;
        layui.each(e, function(e, i) {
            var n = i.children && 0 < i.children.length,
                a = u('<div class="layui-tree-pack" ' + (i.spread ? 'style="display: block;"' : "") + "></div>"),
                t = u(['<div data-id="' + i.id + '" class="layui-tree-set' + (i.spread ? " layui-tree-spread" : "") + (i.checked ? " layui-tree-checkedFirst" : "") + '">', '<div class="layui-tree-entry">', '<div class="layui-tree-main">', c.showLine ? n ? '<span class="layui-tree-iconClick layui-tree-icon"><i class="layui-icon ' + (i.spread ? "layui-icon-subtraction" : "layui-icon-addition") + '"></i></span>' : '<span class="layui-tree-iconClick"><i class="layui-icon layui-icon-file"></i></span>' : '<span class="layui-tree-iconClick"><i class="layui-tree-iconArrow ' + (n ? "" : y) + '"></i></span>', c.showCheckbox ? '<input type="checkbox" name="' + (i.field || "layuiTreeCheck_" + i.id) + '" same="layuiTreeCheck" lay-skin="primary" ' + (i.disabled ? "disabled" : "") + ' value="' + i.id + '">' : "", c.isJump && i.href ? '<a href="' + i.href + '" target="_blank" class="' + b + '">' + (i.title || i.label || c.text.defaultNodeName) + "</a>" : '<span class="' + b + (i.disabled ? " " + d : "") + '">' + (i.title || i.label || c.text.defaultNodeName) + "</span>", "</div>", function() {
                    if (!c.edit) return "";
                    var n = {
                        add: '<i class="layui-icon layui-icon-add-1"  data-type="add"></i>',
                        update: '<i class="layui-icon layui-icon-edit" data-type="update"></i>',
                        del: '<i class="layui-icon layui-icon-delete" data-type="del"></i>'
                    },
                        a = ['<div class="layui-btn-group layui-tree-btnGroup">'];
                    return !0 === c.edit && (c.edit = ["update", "del"]), "object" == typeof c.edit ? (layui.each(c.edit, function(e, i) {
                        a.push(n[i] || "")
                    }), a.join("") + "</div>") : void 0
                }(), "</div></div>"].join(""));
            n && (t.append(a), r.tree(a, i.children)), l.append(t), t.prev("." + f)[0] && t.prev().children(".layui-tree-pack").addClass("layui-tree-showLine"), n || t.parent(".layui-tree-pack").addClass("layui-tree-lineExtend"), r.spread(t, i), c.showCheckbox && (i.checked && r.checkids.push(i.id), r.checkClick(t, i)), c.edit && r.operate(t, i)
        })
    }, l.prototype.spread = function(a, e) {
        var t = this.config,
            i = a.children("." + m),
            n = i.children("." + x),
            l = i.find("." + C),
            i = i.find("." + b),
            r = t.onlyIconControl ? l : n,
            c = "";
        r.on("click", function(e) {
            var i = a.children("." + g),
                n = (r.children(".layui-icon")[0] ? r : r.find(".layui-tree-icon")).children(".layui-icon");
            i[0] ? a.hasClass(w) ? (a.removeClass(w), i.slideUp(200), n.removeClass(v).addClass(k)) : (a.addClass(w), i.slideDown(200), n.addClass(v).removeClass(k), t.accordion && ((i = a.siblings("." + f)).removeClass(w), i.children("." + g).slideUp(200), i.find(".layui-tree-icon").children(".layui-icon").removeClass(v).addClass(k))) : c = "normal"
        }), i.on("click", function() {
            u(this).hasClass(d) || (c = a.hasClass(w) ? t.onlyIconControl ? "open" : "close" : t.onlyIconControl ? "close" : "open", t.click && t.click({
                elem: a,
                state: c,
                data: e
            }))
        })
    }, l.prototype.setCheckbox = function(e, i, n) {
        this.config;
        var t, l = n.prop("checked");
        n.prop("disabled") || ("object" != typeof i.children && !e.find("." + g)[0] || e.find("." + g).find('input[same="layuiTreeCheck"]').each(function() {
            this.disabled || (this.checked = l)
        }), (t = function(e) {
            var i, n, a;
            e.parents("." + f)[0] && (n = (e = e.parent("." + g)).parent(), a = e.prev().find('input[same="layuiTreeCheck"]'), l ? a.prop("checked", l) : (e.find('input[same="layuiTreeCheck"]').each(function() {
                this.checked && (i = !0)
            }), i || a.prop("checked", !1)), t(n))
        })(e), this.renderForm("checkbox"))
    }, l.prototype.checkClick = function(n, a) {
        var t = this,
            l = t.config;
        n.children("." + m).children("." + x).on("click", 'input[same="layuiTreeCheck"]+', function(e) {
            layui.stope(e);
            var e = u(this).prev(),
                i = e.prop("checked");
            e.prop("disabled") || (t.setCheckbox(n, a, e), l.oncheck && l.oncheck({
                elem: n,
                checked: i,
                data: a
            }))
        })
    }, l.prototype.operate = function(c, d) {
        var s = this,
            o = s.config,
            e = c.children("." + m),
            h = e.children("." + x);
        e.children(".layui-tree-btnGroup").on("click", ".layui-icon", function(e) {
            layui.stope(e);
            var i, e = u(this).data("type"),
                a = c.children("." + g),
                t = {
                    data: d,
                    type: e,
                    elem: c
                };
            if ("add" == e) {
                a[0] || (o.showLine ? (h.find("." + C).addClass("layui-tree-icon"), h.find("." + C).children(".layui-icon").addClass(k).removeClass("layui-icon-file")) : h.find(".layui-tree-iconArrow").removeClass(y), c.append('<div class="layui-tree-pack"></div>'));
                var n, l = o.operate && o.operate(t),
                    r = {};
                if (r.title = o.text.defaultNodeName, r.id = l, s.tree(c.children("." + g), [r]), o.showLine && (a[0] ? (a.hasClass(L) || a.addClass(L), c.find("." + g).each(function() {
                    u(this).children("." + f).last().addClass(N)
                }), (a.children("." + f).last().prev().hasClass(N) ? a.children("." + f).last().prev() : a.children("." + f).last()).removeClass(N), !c.parent("." + g)[0] && c.next()[0] && a.children("." + f).last().removeClass(N)) : (l = c.siblings("." + f), n = 1, r = c.parent("." + g), layui.each(l, function(e, i) {
                    u(i).children("." + g)[0] || (n = 0)
                }), 1 == n ? (l.children("." + g).addClass(T), l.children("." + g).children("." + f).removeClass(N), c.children("." + g).addClass(T), r.removeClass(L), r.children("." + f).last().children("." + g).children("." + f).last().addClass(N)) : c.children("." + g).children("." + f).addClass(N))), !o.showCheckbox) return;
                h.find('input[same="layuiTreeCheck"]')[0].checked && (c.children("." + g).children("." + f).last().find('input[same="layuiTreeCheck"]')[0].checked = !0), s.renderForm("checkbox")
            } else "update" == e ? (l = h.children("." + b).html(), h.children("." + b).html(""), h.append('<input type="text" class="layui-tree-editInput">'), h.children(".layui-tree-editInput").val(l).focus(), i = function(e) {
                var i = (i = e.val().trim()) || o.text.defaultNodeName;
                e.remove(), h.children("." + b).html(i), t.data.title = i, o.operate && o.operate(t)
            }, h.children(".layui-tree-editInput").blur(function() {
                i(u(this))
            }), h.children(".layui-tree-editInput").on("keydown", function(e) {
                13 === e.keyCode && (e.preventDefault(), i(u(this)))
            })) : p.confirm('\u786e\u8ba4\u5220\u9664\u8be5\u8282\u70b9 "<span style="color: #999;">' + (d.title || "") + '</span>" \u5417\uff1f', function(e) {
                if (o.operate && o.operate(t), t.status = "remove", p.close(e), !c.prev("." + f)[0] && !c.next("." + f)[0] && !c.parent("." + g)[0]) return c.remove(), void s.elem.append(s.elemNone);
                var l, n, i;
                c.siblings("." + f).children("." + m)[0] ? (o.showCheckbox && (l = function(e) {
                    var i, n, a, t;
                    e.parents("." + f)[0] && (i = e.siblings("." + f).children("." + m), n = (e = e.parent("." + g).prev()).find('input[same="layuiTreeCheck"]')[0], a = 1, (t = 0) == n.checked && (i.each(function(e, i) {
                        i = u(i).find('input[same="layuiTreeCheck"]')[0];
                        0 != i.checked || i.disabled || (a = 0), i.disabled || (t = 1)
                    }), 1 == a && 1 == t && (n.checked = !0, s.renderForm("checkbox"), l(e.parent("." + f)))))
                })(c), o.showLine && (e = c.siblings("." + f), n = 1, i = c.parent("." + g), layui.each(e, function(e, i) {
                    u(i).children("." + g)[0] || (n = 0)
                }), 1 == n ? (a[0] || (i.removeClass(L), e.children("." + g).addClass(T), e.children("." + g).children("." + f).removeClass(N)), (c.next()[0] ? i.children("." + f).last() : c.prev()).children("." + g).children("." + f).last().addClass(N), c.next()[0] || c.parents("." + f)[1] || c.parents("." + f).eq(0).next()[0] || c.prev("." + f).addClass(N)) : !c.next()[0] && c.hasClass(N) && c.prev().addClass(N))) : (e = c.parent("." + g).prev(), o.showLine ? (e.find("." + C).removeClass("layui-tree-icon"), e.find("." + C).children(".layui-icon").removeClass(v).addClass("layui-icon-file"), (i = e.parents("." + g).eq(0)).addClass(L), i.children("." + f).each(function() {
                    u(this).children("." + g).children("." + f).last().addClass(N)
                })) : e.find(".layui-tree-iconArrow").addClass(y), c.parents("." + f).eq(0).removeClass(w), c.parent("." + g).remove()), c.remove()
            })
        })
    }, l.prototype.events = function() {
        var i = this,
            t = i.config;
        i.elem.find(".layui-tree-checkedFirst");
        i.setChecked(i.checkids), i.elem.find(".layui-tree-search").on("keyup", function() {
            var e = u(this),
                n = e.val(),
                e = e.nextAll(),
                a = [];
            e.find("." + b).each(function() {
                var i, e = u(this).parents("." + m); - 1 != u(this).html().indexOf(n) && (a.push(u(this).parent()), (i = function(e) {
                    e.addClass("layui-tree-searchShow"), e.parent("." + g)[0] && i(e.parent("." + g).parent("." + f))
                })(e.parent("." + f)))
            }), e.find("." + m).each(function() {
                var e = u(this).parent("." + f);
                e.hasClass("layui-tree-searchShow") || e.addClass(y)
            }), 0 == e.find(".layui-tree-searchShow").length && i.elem.append(i.elemNone), t.onsearch && t.onsearch({
                elem: a
            })
        }), i.elem.find(".layui-tree-search").on("keydown", function() {
            u(this).nextAll().find("." + m).each(function() {
                u(this).parent("." + f).removeClass("layui-tree-searchShow " + y)
            }), u(".layui-tree-emptyText")[0] && u(".layui-tree-emptyText").remove()
        })
    }, l.prototype.getChecked = function() {
        var e = this.config,
            i = [],
            n = [],
            t = (this.elem.find(".layui-form-checked").each(function() {
                i.push(u(this).prev()[0].value)
            }), function(e, a) {
                layui.each(e, function(e, n) {
                    layui.each(i, function(e, i) {
                        if (n.id == i) return delete(i = u.extend({}, n)).children, a.push(i), n.children && (i.children = [], t(n.children, i.children)), !0
                    })
                })
            });
        return t(u.extend({}, e.data), n), n
    }, l.prototype.setChecked = function(l) {
        this.config;
        this.elem.find("." + f).each(function(e, i) {
            var n = u(this).data("id"),
                a = u(i).children("." + m).find('input[same="layuiTreeCheck"]'),
                t = a.next();
            if ("number" == typeof l) {
                if (n.toString() == l.toString()) return a[0].checked || t.click(), !1
            } else "object" == typeof l && layui.each(l, function(e, i) {
                if (i.toString() == n.toString() && !a[0].checked) return t.click(), !0
            })
        })
    }, t.that = {}, t.config = {}, a.reload = function(e, i) {
        e = t.that[e];
        return e.reload(i), t.call(e)
    }, a.getChecked = function(e) {
        return t.that[e].getChecked()
    }, a.setChecked = function(e, i) {
        return t.that[e].setChecked(i)
    }, a.render = function(e) {
        e = new l(e);
        return t.call(e)
    }, e(n, a)
});
layui.define(["laytpl", "form"], function(e) {
    "use strict";
    var s = layui.$,
        n = layui.laytpl,
        t = layui.form,
        a = "transfer",
        i = {
            config: {},
            index: layui[a] ? layui[a].index + 1e4 : 0,
            set: function(e) {
                var t = this;
                return t.config = s.extend({}, t.config, e), t
            },
            on: function(e, t) {
                return layui.onevent.call(this, a, e, t)
            }
        },
        l = function() {
            var t = this,
                e = t.config,
                a = e.id || t.index;
            return l.that[a] = t, {
                config: l.config[a] = e,
                reload: function(e) {
                    t.reload.call(t, e)
                },
                getData: function() {
                    return t.getData.call(t)
                }
            }
        },
        d = "layui-hide",
        h = "layui-btn-disabled",
        r = "layui-none",
        c = "layui-transfer-box",
        u = "layui-transfer-header",
        o = "layui-transfer-search",
        f = "layui-transfer-data",
        y = function(e) {
            return ['<div class="layui-transfer-box" data-index="' + (e = e || {}).index + '">', '<div class="layui-transfer-header">', '<input type="checkbox" name="' + e.checkAllName + '" lay-filter="layTransferCheckbox" lay-type="all" lay-skin="primary" title="{{ d.data.title[' + e.index + "] || 'list" + (e.index + 1) + "' }}\">", "</div>", "{{# if(d.data.showSearch){ }}", '<div class="layui-transfer-search">', '<i class="layui-icon layui-icon-search"></i>', '<input type="input" class="layui-input" placeholder="\u5173\u952e\u8bcd\u641c\u7d22">', "</div>", "{{# } }}", '<ul class="layui-transfer-data"></ul>', "</div>"].join("")
        },
        p = ['<div class="layui-transfer layui-form layui-border-box" lay-filter="LAY-transfer-{{ d.index }}">', y({
            index: 0,
            checkAllName: "layTransferLeftCheckAll"
        }), '<div class="layui-transfer-active">', '<button type="button" class="layui-btn layui-btn-sm layui-btn-primary layui-btn-disabled" data-index="0">', '<i class="layui-icon layui-icon-next"></i>', "</button>", '<button type="button" class="layui-btn layui-btn-sm layui-btn-primary layui-btn-disabled" data-index="1">', '<i class="layui-icon layui-icon-prev"></i>', "</button>", "</div>", y({
            index: 1,
            checkAllName: "layTransferRightCheckAll"
        }), "</div>"].join(""),
        v = function(e) {
            var t = this;
            t.index = ++i.index, t.config = s.extend({}, t.config, i.config, e), t.render()
        };
    v.prototype.config = {
        title: ["\u5217\u8868\u4e00", "\u5217\u8868\u4e8c"],
        width: 200,
        height: 360,
        data: [],
        value: [],
        showSearch: !1,
        id: "",
        text: {
            none: "\u65e0\u6570\u636e",
            searchNone: "\u65e0\u5339\u914d\u6570\u636e"
        }
    }, v.prototype.reload = function(e) {
        var t = this;
        t.config = s.extend({}, t.config, e), t.render()
    }, v.prototype.render = function() {
        var e = this,
            t = e.config,
            a = e.elem = s(n(p).render({
                data: t,
                index: e.index
            })),
            i = t.elem = s(t.elem);
        i[0] && (t.data = t.data || [], t.value = t.value || [], e.key = t.id || e.index, i.html(e.elem), e.layBox = e.elem.find("." + c), e.layHeader = e.elem.find("." + u), e.laySearch = e.elem.find("." + o), e.layData = a.find("." + f), e.layBtn = a.find(".layui-transfer-active .layui-btn"), e.layBox.css({
            width: t.width,
            height: t.height
        }), e.layData.css({
            height: (i = t.height - e.layHeader.outerHeight(), t.showSearch && (i -= e.laySearch.outerHeight()), i - 2)
        }), e.renderData(), e.events())
    }, v.prototype.renderData = function() {
        var e = this,
            i = (e.config, [{
                checkName: "layTransferLeftCheck",
                views: []
            }, {
                checkName: "layTransferRightCheck",
                views: []
            }]);
        e.parseData(function(e) {
            var t = e.selected ? 1 : 0,
                a = ["<li>", '<input type="checkbox" name="' + i[t].checkName + '" lay-skin="primary" lay-filter="layTransferCheckbox" title="' + e.title + '"' + (e.disabled ? " disabled" : "") + (e.checked ? " checked" : "") + ' value="' + e.value + '">', "</li>"].join("");
            i[t].views.push(a), delete e.selected
        }), e.layData.eq(0).html(i[0].views.join("")), e.layData.eq(1).html(i[1].views.join("")), e.renderCheckBtn()
    }, v.prototype.renderForm = function(e) {
        t.render(e, "LAY-transfer-" + this.index)
    }, v.prototype.renderCheckBtn = function(r) {
        var c = this,
            o = c.config;
        r = r || {}, c.layBox.each(function(e) {
            var t = s(this),
                a = t.find("." + f),
                t = t.find("." + u).find('input[type="checkbox"]'),
                i = a.find('input[type="checkbox"]'),
                n = 0,
                l = !1;
            i.each(function() {
                var e = s(this).data("hide");
                (this.checked || this.disabled || e) && n++, this.checked && !e && (l = !0)
            }), t.prop("checked", l && n === i.length), c.layBtn.eq(e)[l ? "removeClass" : "addClass"](h), r.stopNone || (i = a.children("li:not(." + d + ")").length, c.noneView(a, i ? "" : o.text.none))
        }), c.renderForm("checkbox")
    }, v.prototype.noneView = function(e, t) {
        var a = s('<p class="layui-none">' + (t || "") + "</p>");
        e.find("." + r)[0] && e.find("." + r).remove(), t.replace(/\s/g, "") && e.append(a)
    }, v.prototype.setValue = function() {
        var e = this.config,
            t = [];
        return this.layBox.eq(1).find("." + f + ' input[type="checkbox"]').each(function() {
            s(this).data("hide") || t.push(this.value)
        }), e.value = t, this
    }, v.prototype.parseData = function(t) {
        var i = this.config,
            n = [];
        return layui.each(i.data, function(e, a) {
            a = ("function" == typeof i.parseData ? i.parseData(a) : a) || a, n.push(a = s.extend({}, a)), layui.each(i.value, function(e, t) {
                t == a.value && (a.selected = !0)
            }), t && t(a)
        }), i.data = n, this
    }, v.prototype.getData = function(e) {
        var t = this.config,
            i = [];
        return this.setValue(), layui.each(e || t.value, function(e, a) {
            layui.each(t.data, function(e, t) {
                delete t.selected, a == t.value && i.push(t)
            })
        }), i
    }, v.prototype.transfer = function(e, t) {
        var a, i = this,
            n = i.config,
            l = i.layBox.eq(e),
            r = [],
            t = (t ? ((a = (t = t).find('input[type="checkbox"]'))[0].checked = !1, l.siblings("." + c).find("." + f).append(t.clone()), t.remove(), r.push(a[0].value), i.setValue()) : l.each(function(e) {
                s(this).find("." + f).children("li").each(function() {
                    var e = s(this),
                        t = e.find('input[type="checkbox"]'),
                        a = t.data("hide");
                    t[0].checked && !a && (t[0].checked = !1, l.siblings("." + c).find("." + f).append(e.clone()), e.remove(), r.push(t[0].value)), i.setValue()
                })
            }), i.renderCheckBtn(), l.siblings("." + c).find("." + o + " input"));
        "" !== t.val() && t.trigger("keyup"), n.onchange && n.onchange(i.getData(r), e)
    }, v.prototype.events = function() {
        var n = this,
            l = n.config;
        n.elem.on("click", 'input[lay-filter="layTransferCheckbox"]+', function() {
            var e = s(this).prev(),
                t = e[0].checked,
                a = e.parents("." + c).eq(0).find("." + f);
            e[0].disabled || ("all" === e.attr("lay-type") && a.find('input[type="checkbox"]').each(function() {
                this.disabled || (this.checked = t)
            }), setTimeout(function() {
                n.renderCheckBtn({
                    stopNone: !0
                })
            }, 0))
        }), n.elem.on("dblclick", "." + f + ">li", function(e) {
            var t = s(this),
                a = t.children('input[type="checkbox"]'),
                i = t.parent().parent();
            a[0].disabled || n.transfer(i.data("index"), t)
        }), n.layBtn.on("click", function() {
            var e = s(this),
                t = e.data("index");
            e.hasClass(h) || n.transfer(t)
        }), n.laySearch.find("input").on("keyup", function() {
            var i = this.value,
                e = s(this).parents("." + o).eq(0).siblings("." + f),
                t = e.children("li"),
                t = (t.each(function() {
                    var e = s(this),
                        t = e.find('input[type="checkbox"]'),
                        a = t[0].title,
                        a = ("cs" !== l.showSearch && (a = a.toLowerCase(), i = i.toLowerCase()), -1 !== a.indexOf(i));
                    e[a ? "removeClass" : "addClass"](d), t.data("hide", !a)
                }), n.renderCheckBtn(), t.length === e.children("li." + d).length);
            n.noneView(e, t ? l.text.searchNone : "")
        })
    }, l.that = {}, l.config = {}, i.reload = function(e, t) {
        e = l.that[e];
        return e.reload(t), l.call(e)
    }, i.getData = function(e) {
        return l.that[e].getData()
    }, i.render = function(e) {
        e = new v(e);
        return l.call(e)
    }, e(a, i)
});
layui.define("jquery", function(e) {
    "use strict";
    var a = layui.$,
        n = (layui.hint(), layui.device(), {
            config: {},
            set: function(e) {
                var i = this;
                return i.config = a.extend({}, i.config, e), i
            },
            on: function(e, i) {
                return layui.onevent.call(this, r, e, i)
            }
        }),
        r = "carousel",
        d = "layui-this",
        s = "layui-carousel-left",
        u = "layui-carousel-right",
        c = "layui-carousel-prev",
        m = "layui-carousel-next",
        t = "layui-carousel-arrow",
        o = "layui-carousel-ind",
        i = function(e) {
            var i = this;
            i.config = a.extend({}, i.config, n.config, e), i.render()
        };
    i.prototype.config = {
        width: "600px",
        height: "280px",
        full: !1,
        arrow: "hover",
        indicator: "inside",
        autoplay: !0,
        interval: 3e3,
        anim: "",
        trigger: "click",
        index: 0
    }, i.prototype.render = function() {
        var e = this,
            i = e.config;
        i.elem = a(i.elem), i.elem[0] && (e.elemItem = i.elem.find(">*[carousel-item]>*"), i.index < 0 && (i.index = 0), i.index >= e.elemItem.length && (i.index = e.elemItem.length - 1), i.interval < 800 && (i.interval = 800), i.full ? i.elem.css({
            position: "fixed",
            width: "100%",
            height: "100%",
            zIndex: 9999
        }) : i.elem.css({
            width: i.width,
            height: i.height
        }), i.elem.attr("lay-anim", i.anim), e.elemItem.eq(i.index).addClass(d), e.elemItem.length <= 1 || (e.indicator(), e.arrow(), e.autoplay(), e.events()))
    }, i.prototype.reload = function(e) {
        var i = this;
        clearInterval(i.timer), i.config = a.extend({}, i.config, e), i.render()
    }, i.prototype.prevIndex = function() {
        var e = this.config.index - 1;
        return e = e < 0 ? this.elemItem.length - 1 : e
    }, i.prototype.nextIndex = function() {
        var e = this.config.index + 1;
        return e = e >= this.elemItem.length ? 0 : e
    }, i.prototype.addIndex = function(e) {
        var i = this.config;
        i.index = i.index + (e = e || 1), i.index >= this.elemItem.length && (i.index = 0)
    }, i.prototype.subIndex = function(e) {
        var i = this.config;
        i.index = i.index - (e = e || 1), i.index < 0 && (i.index = this.elemItem.length - 1)
    }, i.prototype.autoplay = function() {
        var e = this,
            i = e.config;
        i.autoplay && (clearInterval(e.timer), e.timer = setInterval(function() {
            e.slide()
        }, i.interval))
    }, i.prototype.arrow = function() {
        var i = this,
            e = i.config,
            n = a(['<button class="layui-icon ' + t + '" lay-type="sub">' + ("updown" === e.anim ? "&#xe619;" : "&#xe603;") + "</button>", '<button class="layui-icon ' + t + '" lay-type="add">' + ("updown" === e.anim ? "&#xe61a;" : "&#xe602;") + "</button>"].join(""));
        e.elem.attr("lay-arrow", e.arrow), e.elem.find("." + t)[0] && e.elem.find("." + t).remove(), e.elem.append(n), n.on("click", function() {
            var e = a(this).attr("lay-type");
            i.slide(e)
        })
    }, i.prototype.jump = function(e) {
        var i = this,
            n = i.config;
        e > n.index ? i.slide("add", e - n.index) : e < n.index && i.slide("sub", n.index - e)
    }, i.prototype.indicator = function() {
        var i, e = this,
            n = e.config,
            t = e.elemInd = a(['<div class="' + o + '"><ul>', (i = [], layui.each(e.elemItem, function(e) {
                i.push("<li" + (n.index === e ? ' class="layui-this"' : "") + "></li>")
            }), i.join("")), "</ul></div>"].join(""));
        n.elem.attr("lay-indicator", n.indicator), n.elem.find("." + o)[0] && n.elem.find("." + o).remove(), n.elem.append(t), "updown" === n.anim && t.css("margin-top", -t.height() / 2), t.find("li").on("hover" === n.trigger ? "mouseover" : n.trigger, function() {
            e.jump(a(this).index())
        })
    }, i.prototype.slide = function(e, i) {
        var n = this,
            t = n.elemItem,
            a = n.config,
            o = a.index,
            l = a.elem.attr("lay-filter");
        n.haveSlide || ("sub" === e ? (n.subIndex(i), t.eq(a.index).addClass(c), setTimeout(function() {
            t.eq(o).addClass(u), t.eq(a.index).addClass(u)
        }, 50)) : (n.addIndex(i), t.eq(a.index).addClass(m), setTimeout(function() {
            t.eq(o).addClass(s), t.eq(a.index).addClass(s)
        }, 50)), setTimeout(function() {
            t.removeClass(d + " " + c + " " + m + " " + s + " " + u), t.eq(a.index).addClass(d), n.haveSlide = !1
        }, 300), n.elemInd.find("li").eq(a.index).addClass(d).siblings().removeClass(d), n.haveSlide = !0, e = {
            index: a.index,
            prevIndex: o,
            item: t.eq(a.index)
        }, "function" == typeof a.change && a.change(e), layui.event.call(this, r, "change(" + l + ")", e))
    }, i.prototype.events = function() {
        var e = this,
            i = e.config;
        i.elem.data("haveEvents") || (i.elem.on("mouseenter", function() {
            "always" !== e.config.autoplay && clearInterval(e.timer)
        }).on("mouseleave", function() {
            "always" !== e.config.autoplay && e.autoplay()
        }), i.elem.data("haveEvents", !0))
    }, n.render = function(e) {
        return new i(e)
    }, e(r, n)
});
layui.define("jquery", function(e) {
    "use strict";
    var u = layui.jquery,
        l = {
            config: {},
            index: layui.rate ? layui.rate.index + 1e4 : 0,
            set: function(e) {
                var a = this;
                return a.config = u.extend({}, a.config, e), a
            },
            on: function(e, a) {
                return layui.onevent.call(this, i, e, a)
            }
        },
        i = "rate",
        c = "layui-icon-rate",
        r = "layui-icon-rate-solid",
        o = "layui-icon-rate-half",
        s = "layui-icon-rate-solid layui-icon-rate-half",
        f = "layui-icon-rate layui-icon-rate-half",
        a = function(e) {
            var a = this;
            a.index = ++l.index, a.config = u.extend({}, a.config, l.config, e), a.render()
        };
    a.prototype.config = {
        length: 5,
        text: !1,
        readonly: !1,
        half: !1,
        value: 0,
        theme: ""
    }, a.prototype.render = function() {
        for (var e = this, a = e.config, l = a.theme ? 'style="color: ' + a.theme + ';"' : "", i = (a.elem = u(a.elem), a.value > a.length && (a.value = a.length), parseInt(a.value) === a.value || a.half || (a.value = Math.ceil(a.value) - a.value < .5 ? Math.ceil(a.value) : Math.floor(a.value)), '<ul class="layui-rate" ' + (a.readonly ? "readonly" : "") + ">"), n = 1; n <= a.length; n++) {
            var t = '<li class="layui-inline"><i class="layui-icon ' + (n > Math.floor(a.value) ? c : r) + '" ' + l + "></i></li>";
            a.half && parseInt(a.value) !== a.value && n == Math.ceil(a.value) ? i = i + '<li><i class="layui-icon layui-icon-rate-half" ' + l + "></i></li>" : i += t
        }
        i += "</ul>" + (a.text ? '<span class="layui-inline">' + a.value + "\u661f" : "") + "</span>";
        var o = a.elem,
            s = o.next(".layui-rate");
        s[0] && s.remove(), e.elemTemp = u(i), a.span = e.elemTemp.next("span"), a.setText && a.setText(a.value), o.html(e.elemTemp), o.addClass("layui-inline"), a.readonly || e.action()
    }, a.prototype.setvalue = function(e) {
        this.config.value = e, this.render()
    }, a.prototype.action = function() {
        var i = this.config,
            n = this.elemTemp,
            t = n.find("i").width();
        n.children("li").each(function(e) {
            var a = e + 1,
                l = u(this);
            l.on("click", function(e) {
                i.value = a, i.half && e.pageX - u(this).offset().left <= t / 2 && (i.value = i.value - .5), i.text && n.next("span").text(i.value + "\u661f"), i.choose && i.choose(i.value), i.setText && i.setText(i.value)
            }), l.on("mousemove", function(e) {
                n.find("i").each(function() {
                    u(this).addClass(c).removeClass(s)
                }), n.find("i:lt(" + a + ")").each(function() {
                    u(this).addClass(r).removeClass(f)
                }), i.half && e.pageX - u(this).offset().left <= t / 2 && l.children("i").addClass(o).removeClass(r)
            }), l.on("mouseleave", function() {
                n.find("i").each(function() {
                    u(this).addClass(c).removeClass(s)
                }), n.find("i:lt(" + Math.floor(i.value) + ")").each(function() {
                    u(this).addClass(r).removeClass(f)
                }), i.half && parseInt(i.value) !== i.value && n.children("li:eq(" + Math.floor(i.value) + ")").children("i").addClass(o).removeClass("layui-icon-rate-solid layui-icon-rate")
            })
        })
    }, a.prototype.events = function() {
        this.config
    }, l.render = function(e) {
        e = new a(e);
        return function() {
            var a = this;
            return {
                setvalue: function(e) {
                    a.setvalue.call(a, e)
                },
                config: a.config
            }
        }.call(e)
    }, e(i, l)
});
layui.define("jquery", function(l) {
    "use strict";
    var g = layui.$,
        e = function(l) {};
    e.prototype.load = function(l) {
        var t, i, n, e, r, o, a, c, m, s, u, f, y, d = this,
            p = 0,
            h = g((l = l || {}).elem);
        if (h[0]) return e = g(l.scrollElem || document), r = l.mb || 50, o = !("isAuto" in l) || l.isAuto, a = l.end || "\u6ca1\u6709\u66f4\u591a\u4e86", c = l.scrollElem && l.scrollElem !== document, m = "<cite>\u52a0\u8f7d\u66f4\u591a</cite>", s = g('<div class="layui-flow-more"><a href="javascript:;">' + m + "</a></div>"), h.find(".layui-flow-more")[0] || h.append(s), u = function(l, e) {
            l = g(l), s.before(l), (e = 0 == e || null) ? s.html(a) : s.find("a").html(m), i = e, t = null, y && y()
        }, f = function() {
            t = !0, s.find("a").html('<i class="layui-anim layui-anim-rotate layui-anim-loop layui-icon ">&#xe63e;</i>'), "function" == typeof l.done && l.done(++p, u)
        }, f(), s.find("a").on("click", function() {
            g(this);
            i || t || f()
        }), l.isLazyimg && (y = d.lazyimg({
            elem: l.elem + " img",
            scrollElem: l.scrollElem
        })), o && e.on("scroll", function() {
            var e = g(this),
                o = e.scrollTop();
            n && clearTimeout(n), !i && h.width() && (n = setTimeout(function() {
                var l = (c ? e : g(window)).height();
                (c ? e.prop("scrollHeight") : document.documentElement.scrollHeight) - o - l <= r && (t || f())
            }, 100))
        }), d
    }, e.prototype.lazyimg = function(l) {
        var e, c = this,
            m = 0,
            s = g((l = l || {}).scrollElem || document),
            u = l.elem || "img",
            f = l.scrollElem && l.scrollElem !== document,
            y = function(e, l) {
                var o, t = s.scrollTop(),
                    l = t + l,
                    i = f ? e.offset().top - s.offset().top + t : e.offset().top;
                t <= i && i <= l && e.attr("lay-src") && (o = e.attr("lay-src"), layui.img(o, function() {
                    var l = c.lazyimg.elem.eq(m);
                    e.attr("src", o).removeAttr("lay-src"), l[0] && n(l), m++
                }, function() {
                    c.lazyimg.elem.eq(m);
                    e.removeAttr("lay-src")
                }))
            },
            n = function(l, e) {
                var o = (f ? e || s : g(window)).height(),
                    t = s.scrollTop(),
                    i = t + o;
                if (c.lazyimg.elem = g(u), l) y(l, o);
                else for (var n = 0; n < c.lazyimg.elem.length; n++) {
                    var r = c.lazyimg.elem.eq(n),
                        a = f ? r.offset().top - s.offset().top + t : r.offset().top;
                    if (y(r, o), m = n, i < a) break
                }
            };
        return n(), s.on("scroll", function() {
            var l = g(this);
            e && clearTimeout(e), e = setTimeout(function() {
                n(null, l)
            }, 50)
        }), n
    }, l("flow", new e)
});
layui.define(["lay", "util"], function(e) {
    "use strict";
    var d = layui.$,
        o = layui.util,
        u = "layui-code-title",
        l = {
            elem: ".layui-code",
            title: "&lt;/&gt;",
            about: "",
            ln: !0
        };
    e("code", function(e) {
        var c = e = d.extend({}, l, e);
        e.elem = d(e.elem), e.elem[0] && layui.each(e.elem.get().reverse(), function(e, l) {
            var a, t = d(l),
                i = (i = t.html(), d.trim(i).replace(/^\n|\n$/, "")),
                l = d.extend({}, c, lay.options(l), (a = {}, layui.each(["title", "height", "encode", "skin", "about"], function(e, l) {
                    var i = t.attr("lay-" + l);
                    "string" == typeof i && (a[l] = i)
                }), a)),
                s = l.ln ? "ol" : "ul",
                s = d("<" + s + ' class="layui-code-' + s + '">'),
                n = d('<div class="' + u + '">');
            t.addClass("layui-code-view layui-box"), l.skin && ("notepad" === l.skin && (l.skin = "dark"), t.addClass("layui-code-" + l.skin)), i = (i = l.encode ? o.escape(i) : i).replace(/[\r\t\n]+/g, "</li><li>"), t.html(s.html("<li>" + i + "</li>")), t.children("." + u)[0] || (n.html(l.title + (l.about ? '<div class="layui-code-about">' + l.about + "</div>" : "")), t.prepend(n)), 0 < (i = Math.floor(s.find("li").length / 100)) && s.css("margin-left", i + "px"), l.height && s.css("max-height", l.height)
        })
    })
}), layui["layui.all"] || layui.addcss("modules/code.css?v=3", "skincodecss");